1、從最簡單的Access(文件型數(shù)據(jù)庫)開始吧,軟件網(wǎng)上有下載,首先基礎(chǔ)的概念必須掌握,比如什么叫表、什么叫主鍵。。。。。。
成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的福州網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
2、根據(jù)教材上的示例自己建幾個簡單的庫,熟悉各種操作。
3、學(xué)習(xí)SQL語句,掌握查詢的用法。
4、做更多的實(shí)例加深理解,掌握學(xué)到的東西。
5、學(xué)習(xí)SQLserver掌握試圖、存儲過程、觸發(fā)器、游標(biāo)等用法,掌握關(guān)系型數(shù)據(jù)庫的基本操作。
6、深入學(xué)習(xí)大型數(shù)據(jù)庫的知識,熟練復(fù)雜SQL語句的書寫。
7、根據(jù)需要再掌握Oracle、DB2等大型數(shù)據(jù)庫。有了前面的基礎(chǔ),不論學(xué)習(xí)什么品牌的數(shù)據(jù)庫都會比較容易上手。
先給出我的核心觀點(diǎn):
學(xué)習(xí),無論你是學(xué)什么,也無論你有沒有基礎(chǔ)。思考永遠(yuǎn)是第一位的,有些知識你沒接觸過不要緊,用不著害怕,也沒必要害怕。重要的是一秒鐘也不要停止思考,問題要想透徹,正所謂磨刀不誤砍柴工。尤其是作為工程師,要有打破砂鍋問到底的精神,否則你怎么學(xué)都沒用。
首先,學(xué)習(xí)基本的SQL語法。完成這個后,你就可以編寫SQL語句了。這一步推薦:W3Schools的 SQL 教程。
其次,學(xué)習(xí)數(shù)據(jù)庫的主要功能和使用方法,比如用戶相關(guān)或者權(quán)限相關(guān)等等。
我推薦兩本書:
一、《MySQL必知必會》 這本書講的非常全,從基本概念,到查詢到插入新建表,用戶的管理,都有具體的例子,非常適合沒有任何基礎(chǔ)的同學(xué)來學(xué)習(xí)Mysql,總之這本書學(xué)習(xí)的方法就是:1、十分鐘了解下數(shù)據(jù)庫的基本概念 2、找到練手的數(shù)據(jù)庫 3、對照著上面的內(nèi)容去敲。本書里也有大量的內(nèi)容是講sql的,可以結(jié)合w3c的sql教程一起,有取舍地看。
二、《數(shù)據(jù)庫系統(tǒng)概念》這本書是dba必看的??赐赀@些并且實(shí)踐+思考之后,可以算入門了。接下來對于希望深入學(xué)習(xí)的童鞋我推薦幾本書(很多大神都這么推薦),《高性能MySQL(第3版)》、 《MySQL技術(shù)內(nèi)幕(第4版)》,《MySQL技術(shù)內(nèi)幕 InnoDB存儲引擎》,《深入理解MySQL》還有Mysql的官網(wǎng)。讀完這些東西,再加些豐富的經(jīng)驗(yàn),理論上來講就具備DBA的水平了。十分推薦閱讀Planet MySQL上匯總的博客,特別是Percona's MySQL InnoDB performance and scalability blog但是,正如我開頭所言的。
面對問題的時候一定要積極思考!比如:我問你,面對一個并發(fā)量比較高的場景,如何配置mysql的連接數(shù)?你可能會回答:“哦,就是調(diào)高max_connection的數(shù)值吧?!蹦牵阌袥]有思考過調(diào)到多少是最合適的呢?為什么這樣設(shè)置就最合適呢?也許你會回答:“恩我知道,可以看系統(tǒng)之前的max_used_connection的數(shù)值,然后來設(shè)置。也可以調(diào)高back_log的值。”那你有沒有思考過,max_connection連接數(shù)太高會有什么不好的影響呢?back_log設(shè)置的太高有什么不好的地方呢?max_connect的上限其實(shí)是取決于mysql能獲得的文件描述符的數(shù)量,也就是說你就算設(shè)置成10000,最后也是沒用的,系統(tǒng)會根據(jù)機(jī)器的情況自動調(diào)低。也許你會回答:“恩我知道,設(shè)置太高,會有系統(tǒng)開銷...”那你有沒有思考過,這些開銷具體是什么呢?是什么工作導(dǎo)致了需要這些內(nèi)存開銷?也許你還會回答,在連接創(chuàng)建的時候,會立刻為它分配連接緩沖區(qū)以及查詢緩沖區(qū),這些都會吃內(nèi)存。那你有沒有思考過,占據(jù)的資源具體是多少呢?取決于哪些因素呢?好了,我們先結(jié)束這個問題。回到知乎的問題上來,其實(shí)我說了這么多,就是表達(dá)要如何自學(xué)mysql。所以的所以,你必須不斷思考,才能在工作中面對具體場景的時候,非常淡定地推斷:“哦,一定是這里出了問題。應(yīng)該怎么怎么做。”面對問題,拿出打破砂鍋問到底的精神,先思考一番,給出自己的假設(shè),不要著急地去找度娘,谷歌。思考過后,帶著你的推斷或者答案,大膽地去搜索吧!去看看別人的見解,去看看官方的描述!這才是一個工程師應(yīng)有的態(tài)度。最后我想給出一些有價值的學(xué)習(xí)資料。可以省去一些時間。-電子書:我認(rèn)為多看書還是有好處的。有些書值得反復(fù)看許多遍,有時候只看一遍無法深刻理解吸收,思考也不夠充分
如果你沒有 MySQL 的基礎(chǔ),建議可以看看以下書籍:
《MySQL 必知必會》:主要講 SQL 的寫法
《深入淺出 MySQL》:比較全面的講解了 MySQL 的基礎(chǔ)知識,也涉及了一些優(yōu)化。
如果已經(jīng)對 MySQL 比較熟悉了,可以看下面的書籍:
《高性能 MySQL》:里面講了很多 MySQL 優(yōu)化技巧。
《MySQL 技術(shù)內(nèi)幕》:講解了很多 MySQL 原理,強(qiáng)力推薦給想深入學(xué)習(xí) MySQL 的同學(xué)。
《MySQL 內(nèi)核:InnoDB 存儲引擎》:想深入研究 MySQL 內(nèi)核及原理的可以看看。
《MySQL 運(yùn)維內(nèi)參》:對 MySQL 源碼感興趣,可以入手。
《MySQL Internals Manual》
《MySQL 5.7 Reference Manual》