先給出我的核心觀點:
成都創(chuàng)新互聯(lián)公司是一家集網站建設,蒙陰企業(yè)網站建設,蒙陰品牌網站建設,網站定制,蒙陰網站建設報價,網絡營銷,網絡優(yōu)化,蒙陰網站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網站。
學習,無論你是學什么,也無論你有沒有基礎。思考永遠是第一位的,有些知識你沒接觸過不要緊,用不著害怕,也沒必要害怕。重要的是一秒鐘也不要停止思考,問題要想透徹,正所謂磨刀不誤砍柴工。尤其是作為工程師,要有打破砂鍋問到底的精神,否則你怎么學都沒用。
首先,學習基本的SQL語法。完成這個后,你就可以編寫SQL語句了。這一步推薦:W3Schools的 SQL 教程。
其次,學習數(shù)據庫的主要功能和使用方法,比如用戶相關或者權限相關等等。
我推薦兩本書:
一、《MySQL必知必會》 這本書講的非常全,從基本概念,到查詢到插入新建表,用戶的管理,都有具體的例子,非常適合沒有任何基礎的同學來學習Mysql,總之這本書學習的方法就是:1、十分鐘了解下數(shù)據庫的基本概念 2、找到練手的數(shù)據庫 3、對照著上面的內容去敲。本書里也有大量的內容是講sql的,可以結合w3c的sql教程一起,有取舍地看。
二、《數(shù)據庫系統(tǒng)概念》這本書是dba必看的??赐赀@些并且實踐+思考之后,可以算入門了。接下來對于希望深入學習的童鞋我推薦幾本書(很多大神都這么推薦),《高性能MySQL(第3版)》、 《MySQL技術內幕(第4版)》,《MySQL技術內幕 InnoDB存儲引擎》,《深入理解MySQL》還有Mysql的官網。讀完這些東西,再加些豐富的經驗,理論上來講就具備DBA的水平了。十分推薦閱讀Planet MySQL上匯總的博客,特別是Percona's MySQL InnoDB performance and scalability blog但是,正如我開頭所言的。
面對問題的時候一定要積極思考!比如:我問你,面對一個并發(fā)量比較高的場景,如何配置mysql的連接數(shù)?你可能會回答:“哦,就是調高max_connection的數(shù)值吧。”那,你有沒有思考過調到多少是最合適的呢?為什么這樣設置就最合適呢?也許你會回答:“恩我知道,可以看系統(tǒng)之前的max_used_connection的數(shù)值,然后來設置。也可以調高back_log的值?!蹦悄阌袥]有思考過,max_connection連接數(shù)太高會有什么不好的影響呢?back_log設置的太高有什么不好的地方呢?max_connect的上限其實是取決于mysql能獲得的文件描述符的數(shù)量,也就是說你就算設置成10000,最后也是沒用的,系統(tǒng)會根據機器的情況自動調低。也許你會回答:“恩我知道,設置太高,會有系統(tǒng)開銷...”那你有沒有思考過,這些開銷具體是什么呢?是什么工作導致了需要這些內存開銷?也許你還會回答,在連接創(chuàng)建的時候,會立刻為它分配連接緩沖區(qū)以及查詢緩沖區(qū),這些都會吃內存。那你有沒有思考過,占據的資源具體是多少呢?取決于哪些因素呢?好了,我們先結束這個問題。回到知乎的問題上來,其實我說了這么多,就是表達要如何自學mysql。所以的所以,你必須不斷思考,才能在工作中面對具體場景的時候,非常淡定地推斷:“哦,一定是這里出了問題。應該怎么怎么做?!泵鎸栴},拿出打破砂鍋問到底的精神,先思考一番,給出自己的假設,不要著急地去找度娘,谷歌。思考過后,帶著你的推斷或者答案,大膽地去搜索吧!去看看別人的見解,去看看官方的描述!這才是一個工程師應有的態(tài)度。最后我想給出一些有價值的學習資料??梢允∪ヒ恍r間。-電子書:我認為多看書還是有好處的。有些書值得反復看許多遍,有時候只看一遍無法深刻理解吸收,思考也不夠充分
多看書。少用工具,多在命令窗口下管理數(shù)據庫,自然而然就會熟悉的。
mysql功能并不像Oracle那樣復雜。官方的幫助文檔永遠是最好的老師。
經過一段時間的學習,你只要看幾遍文檔,好好操作,你離DBA就接進一步了。
加油吧
看你基礎如何了.
你要是 什么都不知道的. 那么可能需要先掌握 基本的 SQL 語言, 然后再在 MYSQL 里面慢慢實踐。
你要是 僅僅知道基本的 SQL 語言的語法, 那么就可以直接 在 MySQL 里面做一些基本的實踐, 然后慢慢的多看一些 別人的例子。然后了解一些 MySQL 的函數(shù)之類的。
你要是 已經對 SQL Server 或者 Oracle 比較熟練了,那么就可以直接 看看 MySQL 與 其他數(shù)據庫之間的差異。基本上就可以了。不必從零開始了。
你勤奮的話,每天花5小時學習,3~5天可以對各個方面有個基本了解。
再結合其他編程語言和具體的項目應用,1~3個月后估計就熟練了。
如果沒人指導有一套視頻或者書籍的話,初學者大概需要兩個月才能簡單熟練的使用MySQL,如果有人指導的話,會把時間縮減到三分之一到六分之一,而且效果還會比沒人指導好的多,還有就是如果之前接觸過相關的SQL的話,也會大量縮減這個學習時間。
一、熟悉MySQL的運行環(huán)境
MySQL數(shù)據庫是在Linux環(huán)境下運行的,建議先熟練Linux系統(tǒng)。選定好架構模式之后就可以開始進入程序開發(fā)和數(shù)據處理的環(huán)節(jié)。
二、有扎實的數(shù)據庫理論知識
MySQL作為關系型數(shù)據庫,在實際的應用中也要學會分析存儲數(shù)據的關系型數(shù)據結構,關系操作集合等。只有對這些內容有一個明確的認識,在設計數(shù)據庫字段、表與表的關系才能考慮周全,避免出現(xiàn)錯誤。
三、熟練的SQL語言運用
任何一種數(shù)據庫的學習,包括MySQL,SQL語句都是位于核心部分的內容。需要注意的是SQL語言的使用要力求簡明扼要,能用一個select搞定的問題并不需要寫更多的union。所以在SQL語言的應用方面要注意高效。