最近,有很多學(xué)員留言讓我整理一下“零基礎(chǔ)如何mysql學(xué)習(xí)?”.今天遼寧電腦培訓(xùn)就整理一下學(xué)習(xí)MySQL你需要掌握的知識點(diǎn)以及送給新手學(xué)習(xí)的建議,希望對大家能夠有所幫助!給新手的學(xué)習(xí)建議:1.在學(xué)習(xí)新的東西的時(shí)候,我們至少從三個(gè)問題開始。
創(chuàng)新互聯(lián)專注于休寧縣網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供休寧縣營銷型網(wǎng)站建設(shè),休寧縣網(wǎng)站制作、休寧縣網(wǎng)頁設(shè)計(jì)、休寧縣網(wǎng)站官網(wǎng)定制、小程序定制開發(fā)服務(wù),打造休寧縣網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供休寧縣網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
What?why?how?2.學(xué)習(xí)需要堅(jiān)持,如果還沒準(zhǔn)備好堅(jiān)持半年比較枯燥的MySQL之旅,那么就別開始。
3.學(xué)習(xí)東西不在多,在精,市面上有非常多的MySQL教程,不要瞎學(xué),今天這里學(xué)一點(diǎn),明天那里學(xué)一點(diǎn),這樣你學(xué)的都只是知識點(diǎn),無法形成一個(gè)知識面,知識網(wǎng)絡(luò)。
4.在學(xué)習(xí)過程中充滿好奇,使用google進(jìn)行問題搜索,千萬不要使用度娘了,質(zhì)量不高。
至于怎么用Google,請自行搜索。
5.學(xué)習(xí)的目的在于使用,因此,不要僅僅看書,看一遍,看兩遍,你可能還是沒什么感覺。
因此學(xué)習(xí)一開始,就要動手練習(xí),把資料上的情況,模擬一下。
6.請不要在windows上安裝mysql進(jìn)行學(xué)習(xí),因?yàn)楣ぷ髦卸际莑inux系統(tǒng)。
我們需要從一開始就是實(shí)戰(zhàn),就是生產(chǎn)環(huán)境。
7.保持好心態(tài),一步一個(gè)腳印的前進(jìn)。
學(xué)習(xí)MySQL你需要掌握的知識點(diǎn):1.系統(tǒng),當(dāng)然windos基本的要會。
然后就是Linux系統(tǒng),現(xiàn)在做MySQLDBA的系統(tǒng)多數(shù)都是Linux系統(tǒng),而生產(chǎn)環(huán)境大多又是RedHat,Centos。
其他的Linux和Unix系統(tǒng)可以只做了解。
2.Linux基礎(chǔ),網(wǎng)絡(luò),IO,內(nèi)存,磁盤,CPU。
包括不限于安裝,啟動過程,目錄結(jié)構(gòu),遠(yuǎn)程登錄,文件屬性與管理,用戶與用戶權(quán)限,LAMP結(jié)構(gòu)vim,yum等shell命令,dns,ftp,以及一些常用工具。
3.MySQL基礎(chǔ):MySQL安裝、MySQL體系結(jié)構(gòu),SQL,MySQL管理維護(hù)。
4.數(shù)據(jù)備份與恢復(fù),常用的引擎:MyISAM、Innodb、NDB等。
5.數(shù)據(jù)庫設(shè)計(jì)優(yōu)化,一個(gè)好的MySQL系統(tǒng),往往從設(shè)計(jì)開始。
6.SQL優(yōu)化,參數(shù)優(yōu)化,監(jiān)控,安全等。
7.MySQL負(fù)載均衡,讀寫分離,MHA,MMM高可用架構(gòu),以及分布式架構(gòu):mycat、maxscale、galeracluster、MySQLGroupReplication等。
8.mysql5.6,mysql5.7新特性,mariadb、percona分支的差異和特點(diǎn)。
9.MySQLJSON、MySQLmemcached。
10.常見MySQL搭配的緩存系統(tǒng),redis,memcached,以及NOSQL、NEWSQL。
以上,就是小編為大家整理的mysql學(xué)習(xí)你需要掌握的知識點(diǎn)以及送給新手學(xué)習(xí)的建議,希望能夠幫助到大家!
對于非計(jì)算機(jī)出身的我,大學(xué)只會hello word和跑馬燈,期間過程確實(shí)非常曲折,分享下我的自學(xué)過程:
1、 自己在windows和linux上安裝了mysql,自學(xué)linux的基礎(chǔ)知識,學(xué)習(xí)mysql的最基礎(chǔ)的知識,即怎么寫sql,存儲過程,表的設(shè)計(jì)等,從0到熟悉大概花了3個(gè)月 ,推薦《mysql入門很簡單》。
2、系統(tǒng)地較為深入地學(xué)習(xí)mysql的sql優(yōu)化,備份和恢復(fù),參數(shù)優(yōu)化,架構(gòu)優(yōu)化,硬件層面的優(yōu)化,高可用方案,復(fù)制技術(shù)等等,這段時(shí)間你不一定能實(shí)際接觸到這些,就像我當(dāng)初那樣,肯定沒什么公司招一個(gè)小白。 我選擇自己看書,推薦《高性能mysql》,里面所有的章節(jié)都需要看一遍,以現(xiàn)在的水平肯定看不懂,但需要知道大概怎么回事,為后續(xù)的找mysql初級dba的工作打一個(gè)鋪墊,這個(gè)過程大概也需要3個(gè)月。
3、 紙上得來終覺淺,完成以上兩步,我開始準(zhǔn)備找一份mysql相關(guān)的工作,而不是天天用著excel表格做著select * from table_sb這樣的工作。 當(dāng)然我這么猥瑣的人肯定不會裸辭,該畫的電路板也一樣畫,業(yè)余時(shí)間開始投初級mysql dba的工作,并且不間斷地學(xué)習(xí),網(wǎng)上各種找mysql面試的相關(guān)題目(實(shí)際上我當(dāng)時(shí)完全沒有任何實(shí)戰(zhàn)經(jīng)驗(yàn)),陸續(xù)收到一些面試,憑借之前自學(xué)的mysql知識,開始胡亂吹牛逼,先混進(jìn)去再說。 你不做mysql實(shí)際相關(guān)的工作,永遠(yuǎn)也不知道自己之前認(rèn)知的db知識有多幼稚。 友情提示一點(diǎn),一般公司都沒有專職dba的,所以面試的時(shí)候一定要自信,其實(shí)你學(xué)了這么多,雖然毫無實(shí)戰(zhàn)經(jīng)驗(yàn),理論知識很大概率比面試你的人牛逼,所以各種吹,我就這樣真正進(jìn)入初級dba的圈子(由于這時(shí)對linux還處于cd ls的水平,所以之前也根本沒做過運(yùn)維),這個(gè)邊工作邊找工作的過程又持續(xù)了2個(gè)月。
4、真正進(jìn)入互聯(lián)網(wǎng),接觸生產(chǎn)環(huán)境后,這是我進(jìn)步最大的時(shí)候。 第一步需要將之前所學(xué)真正地應(yīng)用起來,并且應(yīng)用的過程中,再回頭看之前的書籍,這時(shí)候需要真正去理解,而不是似是而非,一知半解。 這時(shí)再推薦《高性能mysql 第三版》,全本再看一遍,這時(shí)需要全部看懂,另外還有《mysql技術(shù)內(nèi)幕:innodb存儲引擎》等等。 總之這段時(shí)間就需要開始關(guān)注mysql一些細(xì)節(jié)了,比如db故障處理,高可用,負(fù)載均衡等等的具體實(shí)現(xiàn)了。 另外,linux的知識同步也要深入去學(xué)習(xí),至少會寫shell腳本,常見的linux知識等,我在這花了1年多;
5、 dba的工作一般是非常輕閑的,畢竟不是大公司,技術(shù)能力有限,該學(xué)的也學(xué)得差不多了,接觸不到海量數(shù)據(jù),高并發(fā)等比較鍛煉人的場合,于是我又準(zhǔn)備跳了。 于是來了公有云,現(xiàn)在每天運(yùn)維萬多個(gè)db實(shí)例,平均每天處理5+個(gè)緊急db故障,幾乎mysql會遇到的問題,感覺都遇到了,能感覺到技術(shù)實(shí)力和經(jīng)驗(yàn)也在每天都在積累,在進(jìn)步。 但是感覺還是欠缺了很多,下一步就看你選擇了,是再去研究源代碼,底層原理的東西多點(diǎn),還是數(shù)據(jù)庫運(yùn)維和應(yīng)用多一點(diǎn),就比如業(yè)界姜承堯,何登成與葉金榮的區(qū)別。 由于我的歷史原因,對c++等幾乎不懂,平時(shí)也用不到,所以看代碼等事實(shí)際太累,于是我再去學(xué)mongodb,接了公司mongodb運(yùn)維的活,算是在廣度上的一個(gè)擴(kuò)展,萬一哪天mysql不行了呢
6、 總之,對于db小白來說,最重要的一點(diǎn)就是,學(xué)習(xí)的過程不能斷。 PS 上面的方法比較野路子,適合沒什么基礎(chǔ)的童鞋,如果本來就是DBA,比如從oracle轉(zhuǎn)到mysql,那么建議直接看mysql官方文檔,而官方文檔是db達(dá)到一定水平后必看,出問題時(shí)必查的權(quán)威文檔。
首先,學(xué)習(xí)基本的SQL語法。完成這個(gè)后,你就可以編寫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但是,正如我開頭所言的。
面對問題的時(shí)候一定要積極思考!比如:我問你,面對一個(gè)并發(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)建的時(shí)候,會立刻為它分配連接緩沖區(qū)以及查詢緩沖區(qū),這些都會吃內(nèi)存。那你有沒有思考過,占據(jù)的資源具體是多少呢?取決于哪些因素呢?好了,我們先結(jié)束這個(gè)問題。回到知乎的問題上來,其實(shí)我說了這么多,就是表達(dá)要如何自學(xué)mysql。所以的所以,你必須不斷思考,才能在工作中面對具體場景的時(shí)候,非常淡定地推斷:“哦,一定是這里出了問題。應(yīng)該怎么怎么做?!泵鎸栴},拿出打破砂鍋問到底的精神,先思考一番,給出自己的假設(shè),不要著急地去找度娘,谷歌。思考過后,帶著你的推斷或者答案,大膽地去搜索吧!去看看別人的見解,去看看官方的描述!這才是一個(gè)工程師應(yīng)有的態(tài)度。最后我想給出一些有價(jià)值的學(xué)習(xí)資料??梢允∪ヒ恍r(shí)間。-電子書:我認(rèn)為多看書還是有好處的。有些書值得反復(fù)看許多遍,有時(shí)候只看一遍無法深刻理解吸收,思考也不夠充分