這篇文章主要講解了“MySQL該怎么學”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“mysql該怎么學”吧!
溧水ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!
1.使用 C和C++編寫,并使用了多種編譯器進行測試,保證了源代碼的可移植性。
2.支持AIX、FreeBSD、HP-UX、Linux、Mac OS、NovellNetware、OpenBSD、OS/2 Wrap、Solaris、Windows等多種操作系統(tǒng)。
3.為多種編程語言提供了API。這些編程語言包括C、C++、Python、Java、Perl、PHP、Eiffel、Ruby,.NET和 Tcl 等。
4.支持多線程,充分利用 CPU 資源。
5.優(yōu)化的SQL查詢算法,有效地提高查詢速度。
6.既能夠作為一個單獨的應(yīng)用程序應(yīng)用在客戶端服務(wù)器網(wǎng)絡(luò)環(huán)境中,也能夠作為一個庫而嵌入到其他的軟件中。
7.提供多語言支持,常見的編碼如中文的GB 2312、BIG5,日文的Shift_JIS等都可以用作數(shù)據(jù)表名和數(shù)據(jù)列名。
8.提供TCP/IP、ODBC 和JDBC等多種數(shù)據(jù)庫連接途徑。
9.提供用于管理、檢查、優(yōu)化數(shù)據(jù)庫操作的管理工具。
10.支持大型的數(shù)據(jù)庫??梢蕴幚頁碛猩锨f條記錄的大型數(shù)據(jù)庫。
11.支持多種存儲引擎。
12.MySQL 是開源的,所以你不需要支付額外的費用。
13.MySQL 使用標準的SQL數(shù)據(jù)語言形式。
14.MySQL 對 PHP 有很好的支持,PHP是比較流行的 Web 開發(fā)語言。
15.MySQL是可以定制的,采用了GPL協(xié)議,你可以修改源碼來開發(fā)自己的 MySQL 系統(tǒng)。
16.在線 DDL/更改功能,數(shù)據(jù)架構(gòu)支持動態(tài)應(yīng)用程序和開發(fā)人員靈活性(5.6新增)
17.復(fù)制全局事務(wù)標識,可支持自我修復(fù)式集群(5.6新增)
18.復(fù)制無崩潰從機,可提高可用性(5.6新增)
19.復(fù)制多線程從機,可提高性能(5.6新增)
20.3倍更快的性能(5.7[7]新增)
21.新的優(yōu)化器(5.7新增)
22.原生JSON支持(5.7新增)
23.多源復(fù)制(5.7新增)
24.GIS的空間擴展[8](5.7新增)
好噠,那知道了這些之后,我們接下來看調(diào)優(yōu),這也是在面試的過程中被經(jīng)常問到的一些問題,而且隨著互聯(lián)網(wǎng)的發(fā)展,數(shù)據(jù)量的增大,不想引入大數(shù)據(jù)體系的,那只能在數(shù)據(jù)庫上下功夫了,那么對于數(shù)據(jù)庫的調(diào)優(yōu),不知道各位覺得難
看到這張思維導(dǎo)圖,從上往下,不知道在看這篇文章的你有沒有回想一下自己的知識體系中,這些方面是不是很清晰呢?
好,看完這句話,我的重點要來了,你在回想這些知識點的時候,是不是對你的知識點進行了一個回顧和梳理,查漏補缺,你也知道了自己知識點上的不足,是不是可以有針對性的進行學習呢?
我們以分庫和分表為例去進行一個商討
概念:以字段為依據(jù),按照一定策略(hash、range等),將一個庫中的數(shù)據(jù)拆分到多個庫中。
結(jié)果:
每個庫的結(jié)構(gòu)都一樣;
每個庫的數(shù)據(jù)都不一樣,沒有交集;
所有庫的并集是全量數(shù)據(jù);
場景:系統(tǒng)絕對并發(fā)量上來了,分表難以根本上解決問題,并且還沒有明顯的業(yè)務(wù)歸屬來垂直分庫。
分析:庫多了,io和cpu的壓力自然可以成倍緩解。
概念:以字段為依據(jù),按照一定策略(hash、range等),將一個表中的數(shù)據(jù)拆分到多個表中。
結(jié)果:
每個表的結(jié)構(gòu)都一樣;
每個表的數(shù)據(jù)都不一樣,沒有交集;
所有表的并集是全量數(shù)據(jù);
場景:系統(tǒng)絕對并發(fā)量并沒有上來,只是單表的數(shù)據(jù)量太多,影響了SQL效率,加重了CPU負擔,以至于成為瓶頸。推薦:一次SQL查詢優(yōu)化原理分析
分析:表的數(shù)據(jù)量少了,單次SQL執(zhí)行效率高,自然減輕了CPU的負擔。
概念:以表為依據(jù),按照業(yè)務(wù)歸屬不同,將不同的表拆分到不同的庫中。
結(jié)果:
每個庫的結(jié)構(gòu)都不一樣;
每個庫的數(shù)據(jù)也不一樣,沒有交集;
所有庫的并集是全量數(shù)據(jù);
場景:系統(tǒng)絕對并發(fā)量上來了,并且可以抽象出單獨的業(yè)務(wù)模塊。
分析:到這一步,基本上就可以服務(wù)化了。例如,隨著業(yè)務(wù)的發(fā)展一些公用的配置表、字典表等越來越多,這時可以將這些表拆到單獨的庫中,甚至可以服務(wù)化。再有,隨著業(yè)務(wù)的發(fā)展孵化出了一套業(yè)務(wù)模式,這時可以將相關(guān)的表拆到單獨的庫中,甚至可以服務(wù)化。
概念:以字段為依據(jù),按照字段的活躍性,將表中字段拆到不同的表(主表和擴展表)中。
結(jié)果:
每個表的結(jié)構(gòu)都不一樣;
每個表的數(shù)據(jù)也不一樣,一般來說,每個表的字段至少有一列交集,一般是主鍵,用于關(guān)聯(lián)數(shù)據(jù);
所有表的并集是全量數(shù)據(jù);
場景:系統(tǒng)絕對并發(fā)量并沒有上來,表的記錄并不多,但是字段多,并且熱點數(shù)據(jù)和非熱點數(shù)據(jù)在一起,單行數(shù)據(jù)所需的存儲空間較大。以至于數(shù)據(jù)庫緩存的數(shù)據(jù)行減少,查詢時會去讀磁盤數(shù)據(jù)產(chǎn)生大量的隨機讀IO,產(chǎn)生IO瓶頸。
分析:可以用列表頁和詳情頁來幫助理解。垂直分表的拆分原則是將熱點數(shù)據(jù)(可能會冗余經(jīng)常一起查詢的數(shù)據(jù))放在一起作為主表,非熱點數(shù)據(jù)放在一起作為擴展表。這樣更多的熱點數(shù)據(jù)就能被緩存下來,進而減少了隨機讀IO。拆了之后,要想獲得全部數(shù)據(jù)就需要關(guān)聯(lián)兩個表來取數(shù)據(jù)。
但記住,千萬別用join,因為join不僅會增加CPU負擔并且會
好了,到這里,分庫和分表的操作基本就完成了,不知道大家有沒有什么感覺,如果知識只是單純的去看這些知識點,你能記住多久呢?反正如果我長時間不看,就忘了,,但是我不慫 啊,因為我有這張圖,而且比展示出來的更加詳細,所以當我需要用到時候就可以看了,直接就可以拿出來看,哪怕只有10分鐘就夠了。
感謝各位的閱讀,以上就是“mysql該怎么學”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對mysql該怎么學這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!