溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL的使用技巧有哪些

發(fā)布時(shí)間:2021-08-20 19:02:35 來源:億速云 閱讀:126 作者:chen 欄目:web開發(fā)

這篇文章主要介紹“MySQL的使用技巧有哪些”,在日常操作中,相信很多人在MySQL的使用技巧有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”MySQL的使用技巧有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

  命名規(guī)范

  1、庫名、表名、字段名必須使用小寫字母,并采用下劃線分割。

  a)MySQL有配置參數(shù)lower_case_table_names,不可動(dòng)態(tài)更改,Linux系統(tǒng)默認(rèn)為0,即庫表名以實(shí)際情況存儲(chǔ),大小寫敏感。如果是1,以小寫存儲(chǔ),大小寫不敏感。如果是2,以實(shí)際情況存儲(chǔ),但以小寫比較。

在這里小編建了一個(gè)前端學(xué)習(xí)交流扣扣群:132667127,我自己整理的最新的前端資料和高級開發(fā)教程,如果有想需要的,可以加群一起學(xué)習(xí)交流

  b)如果大小寫混合使用,可能存在abc、Abc、ABC等多個(gè)表共存,容易導(dǎo)致混亂。

  c)字段名顯示區(qū)分大小寫,但實(shí)際使?用不區(qū)分,即不可以建立兩個(gè)名字一樣但大小寫不一樣的字段。

  d)為了統(tǒng)一規(guī)范, 庫名、表名、字段名使用小寫字母。

  2、庫名、表名、字段名禁止超過32個(gè)字符。

  庫名、表名、字段名支持最多64個(gè)字符,但為了統(tǒng)一規(guī)范、易于辨識以及減少傳輸量,禁止超過32個(gè)字符。

  3、庫名、表名、字段名禁止使用MySQL保留字。

  當(dāng)庫名、表名、字段名等屬性含有保留字時(shí),SQL語句必須用反引號引用屬性名稱,這將使得SQL語句書寫、SHELL腳本中變量的轉(zhuǎn)義等變得?非常復(fù)雜。

  使用技巧

  1、將大字段、訪問頻率低的字段拆分到單獨(dú)的表中存儲(chǔ),分離冷熱數(shù)據(jù)。

  有利于有效利用緩存,防?止讀入無用的冷數(shù)據(jù),較少磁盤IO,同時(shí)保證熱數(shù)據(jù)常駐內(nèi)存提?高緩存命中率。

  2、表必須有主鍵,推薦使用UNSIGNED自增列作為主鍵。

  表沒有主鍵,INNODB會(huì)默認(rèn)設(shè)置隱藏的主鍵列;沒有主鍵的表在定位數(shù)據(jù)行的時(shí)候非常困難,也會(huì)降低基于行復(fù)制的效率。

  3、禁止冗余索引和重復(fù)索引。

  索引是雙刃劍,會(huì)增加維護(hù)負(fù)擔(dān),增大IO壓力。(a,b,c)、(a,b),后者為冗余索引可以利用前綴索引來達(dá)到加速目的,減輕維護(hù)負(fù)擔(dān)。primary key a;uniq index a;重復(fù)索引增加維護(hù)負(fù)擔(dān)、占用磁盤空間,同時(shí)沒有任何益處。

  4、合理使用覆蓋索引減少IO,避免排序。

  覆蓋索引能從索引中獲取需要的所有字段,從而避免回表進(jìn)行二次查找,節(jié)省IO。

  INNODB存儲(chǔ)引擎中,secondary index(非主鍵索引,又稱為輔助索引、二級索引)沒有直接存儲(chǔ)行地址,而是存儲(chǔ)主鍵值。

  如果用戶需要查詢secondary index中所不包含的數(shù)據(jù)列,則需先通過secondary index查找到主鍵值,然后再通過主鍵查詢到其他數(shù)據(jù)列,因此需要查詢兩次。覆蓋索引則可以在一個(gè)索引中獲取所有需要的數(shù)據(jù),因此效率較高。

  例如SELECT email,uid FROM user_email WHERE uid=xx,如果uid不是主鍵,適當(dāng)時(shí)候可以將索引添加為index(uid,email),以獲得性能提升。

到此,關(guān)于“MySQL的使用技巧有哪些”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI