MySQL開(kāi)發(fā)規(guī)范

一、基礎(chǔ)規(guī)范

表字符集使用 UTF8

所有表都需要添加注釋

不在數(shù)據(jù)庫(kù)中存儲(chǔ)圖?蛇数、文件等大數(shù)據(jù)

禁止在線上做數(shù)據(jù)庫(kù)壓力測(cè)試

禁?從測(cè)試、開(kāi)發(fā)環(huán)境直連數(shù)據(jù)庫(kù)

二、命名規(guī)范

庫(kù)名表名字段名必須有固定的命名長(zhǎng)度啸箫,12個(gè)字符以內(nèi)

庫(kù)名、表名伞芹、字段名禁?止超過(guò)32個(gè)字符忘苛。須見(jiàn)名之意

庫(kù)名、表名唱较、字段名禁?止使?用MySQL保留字

臨時(shí)庫(kù)扎唾、表名必須以tmp為前綴,并以?日期為后綴

備份庫(kù)南缓、表必須以bak為前綴胸遇,并以日期為后綴

表名以 t_ 或者模塊名(或者模塊名(如 cms_))

字段名稱可讀性要高,多個(gè)單詞需用“ _”分割

表名和所有字段都要注釋汉形, 配置項(xiàng)的還需具體值含義表名和所有字段都要注釋? 如:文章?tīng)顟B(tài) :1.已發(fā)送纸镊, 2. 未發(fā)送, 3. 草稿

三概疆、庫(kù)逗威、表、字段開(kāi)發(fā)設(shè)計(jì)規(guī)范

盡可能不使用 TEXT 岔冀、 BLOB 類型

用 DECIMAL 代替 FLOAT 和 DOUBLE 存儲(chǔ)精確浮點(diǎn)數(shù)

越簡(jiǎn)單越好:將字符轉(zhuǎn)化為數(shù)字凯旭、使用 TINYINT 來(lái)代替 ENUM 類型

所有字段均定義為 NOT NULL

INT類型固定占用 4? 字節(jié)存儲(chǔ)

使用 timestamp 存儲(chǔ)時(shí)間

使用 VARBINARY 存儲(chǔ)大小寫(xiě)敏感的變長(zhǎng)字符串

禁止在數(shù)據(jù)庫(kù)中存儲(chǔ)明文密碼,把密碼加密后存儲(chǔ)

避免使用 NULL 字段, NULL 字段很難查詢優(yōu)化尽纽,NULL字段的索引需要額外空間咐蚯,NULL字段的復(fù)合索引無(wú)效

少用 text/blob , varchar 的性能會(huì)比 text 高很多弄贿,實(shí)在避免不了blob春锋,請(qǐng)拆表

數(shù)據(jù)庫(kù)中不允許存儲(chǔ)大文件,或者照片差凹,可以將大對(duì)象放到磁盤(pán)上期奔,數(shù)據(jù)庫(kù)中存儲(chǔ)它的路徑

四、索引規(guī)范

1危尿、索引的數(shù)量要控制:

張表中索引數(shù)量不超過(guò)6個(gè)

單個(gè)索引中的字段數(shù)不超過(guò)5個(gè)

對(duì)字符串使?用前綴索引呐萌,前綴索引長(zhǎng)度不超過(guò)8個(gè)字符

2、主鍵準(zhǔn)則

表必須有主鍵

不使用更新頻繁的列作為主鍵

盡量不選擇字符串列作為主鍵

默認(rèn)使?非空的唯一鍵作為主鍵

建議選擇自增或發(fā)號(hào)器

3谊娇、多表JOIN的字段注意以下

區(qū)分度最大的字段放在前面

核?SQL優(yōu)先考慮覆蓋索引

避免冗余和重復(fù)索引

4肺孤、索引禁忌

不在低基數(shù)列上建立索引,例如“性別”

不在索引列進(jìn)行數(shù)學(xué)運(yùn)算和函數(shù)運(yùn)算

5济欢、索引命名:

非唯一索引必須以idx_字段1命名赠堵,唯一所以必須以 uniq_字段1? 命名,索引名稱必須全部小寫(xiě)

索引字段的默認(rèn)值不能為 NULL 法褥,要改為其他的 default 或者空茫叭。 NULL 非常影響索引的查詢效率

6、能使用唯一索引就要使用唯一索引半等,提高查詢效率

五揍愁、SQL規(guī)范

禁止使用SELECT *,只獲取必要的字段杀饵,需要顯示說(shuō)明列屬性

SQL語(yǔ)句盡可能簡(jiǎn)單莽囤,大的SQL想辦法拆成小的SQL語(yǔ)句

避免使用觸發(fā)器、函數(shù)凹髓、存儲(chǔ)過(guò)程

SQL中使用到OR的改寫(xiě)為用IN()(OR的效率沒(méi)有IN 的效率高)

in里面數(shù)字的個(gè)數(shù)建議控制在 1000 以內(nèi)

LIMIT分頁(yè)注意效率烁登。LIMIT越大,效率越低蔚舀《祝可以改寫(xiě) LIMIT ,比如例子改寫(xiě):

SELECT id FROM t LIMIT 10000, 10; => SELECT id FROM t WHERE id > 10000 LIMIT 10;

使用 UNION ALL 替代? UNION

避免使用大表的 JOIN

使用 GROUP BY 分組赌躺、自動(dòng)排序

SQL語(yǔ)句不可以出現(xiàn)隱式轉(zhuǎn)換狼牺,比如 SELECT id FROM TABLE WHERE id='1'

使用EXIST代替IN,EXIST在一些場(chǎng)景查詢會(huì)比IN快

能不用 NOT IN 就不用 NOTIN 礼患,坑太多了是钥。掠归。會(huì)把空和NULL給查出來(lái)

禁?單條SQL語(yǔ)句同時(shí)更新多個(gè)表

禁止%開(kāi)頭的模糊查詢,會(huì)導(dǎo)致全表掃描

避免使用用子查詢悄泥,改用join

六虏冻、流程規(guī)范

所有的建表操作需要提前告知該表涉及的查詢SQL;

所有的建表需要確定建立哪些索引后才可以建表上線弹囚;

所有的改表結(jié)構(gòu)厨相、加索引操作都需要將涉及到所改表的查詢SQL發(fā)出來(lái)告知相關(guān)人員;

不在業(yè)務(wù)高峰期批量更新鸥鹉、查詢數(shù)據(jù)庫(kù)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蛮穿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子毁渗,更是在濱河造成了極大的恐慌践磅,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件灸异,死亡現(xiàn)場(chǎng)離奇詭異府适,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)绎狭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)细溅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人儡嘶,你說(shuō)我怎么就攤上這事』蟹纾” “怎么了蹦狂?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)朋贬。 經(jīng)常有香客問(wèn)我凯楔,道長(zhǎng),這世上最難降的妖魔是什么锦募? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任摆屯,我火速辦了婚禮,結(jié)果婚禮上糠亩,老公的妹妹穿的比我還像新娘虐骑。我一直安慰自己,他們只是感情好赎线,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布廷没。 她就那樣靜靜地躺著,像睡著了一般垂寥。 火紅的嫁衣襯著肌膚如雪颠黎。 梳的紋絲不亂的頭發(fā)上另锋,一...
    開(kāi)封第一講書(shū)人閱讀 49,071評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音狭归,去河邊找鬼夭坪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛过椎,可吹牛的內(nèi)容都是我干的室梅。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼潭流,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼竞惋!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起灰嫉,我...
    開(kāi)封第一講書(shū)人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤拆宛,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后讼撒,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體浑厚,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年根盒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了钳幅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡炎滞,死狀恐怖敢艰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情册赛,我是刑警寧澤钠导,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站森瘪,受9級(jí)特大地震影響牡属,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜扼睬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一逮栅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧窗宇,春花似錦措伐、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至蝇完,卻和暖如春官硝,著一層夾襖步出監(jiān)牢的瞬間矗蕊,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工氢架, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留傻咖,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓岖研,卻偏偏與公主長(zhǎng)得像卿操,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子孙援,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 庫(kù)表設(shè)計(jì) 庫(kù)名害淤、表名、字段名使用小寫(xiě)字母拓售,”_”分割窥摄,不超過(guò)18 個(gè)字符,使用名詞且見(jiàn)名知意. 不使用temp础淤、o...
    迷途的華生閱讀 1,013評(píng)論 0 10
  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 31,898評(píng)論 2 89
  • (一)建表規(guī)約 1.【強(qiáng)制】在編寫(xiě)建表語(yǔ)句時(shí)崭放,需同時(shí)考慮回滾、以及必要的初始化語(yǔ)句鸽凶;生產(chǎn)環(huán)境變更表或數(shù)據(jù)時(shí)須提供變...
    changxiaonan閱讀 1,022評(píng)論 0 0
  • Mysql概述 數(shù)據(jù)庫(kù)是一個(gè)易于訪問(wèn)和修改的信息集合币砂。它允許使用事務(wù)來(lái)確保數(shù)據(jù)的安全性和一致性,并能快速處理百萬(wàn)條...
    彥幀閱讀 13,656評(píng)論 10 461
  • 一如即往懶惰的我玻侥,難得在這個(gè)寒冷的冬天里抽出自己揣在兜里的手决摧,以填下上一篇情商文章的坑,哈哈凑兰。老規(guī)矩:文章不夠...
    陳坤Th閱讀 327評(píng)論 1 1