數(shù)據(jù)庫規(guī)范

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

必須使用InnoDB存儲引擎
原因:支持事務(wù)、行級鎖、并發(fā)性能更好、CPU及內(nèi)存緩存頁優(yōu)化使得資源利用率更高

數(shù)據(jù)表,字段必須加入注釋
原因:以后新加入的人或者現(xiàn)有人員忘記了數(shù)據(jù)含義,可以通過注釋理解業(yè)務(wù)
命名規(guī)范
表名t_xxx,非唯一索引名idx_xxx,唯一索引名uniq_xxx

庫名、表名、字段名:小寫,下劃線風(fēng)格,不超過32個字符,必須見名知意,禁止拼音英文混用


表設(shè)計規(guī)范

單表列數(shù)目必須小于30

數(shù)據(jù)表PK類型必須是bigint

必須把字段定義為NOT NULL并且提供默認值
原因:

  1. null的列使索引/索引統(tǒng)計/值比較都更加復(fù)雜,對MySQL來說更難優(yōu)化
  2. null 這種類型MySQL內(nèi)部需要進行特殊處理,增加數(shù)據(jù)庫處理記錄的復(fù)雜性;同等條件下,表中有較多空字段的時候,數(shù)據(jù)庫的處理性能會降低很多
  3. null值需要更多的存儲空,無論是表還是索引中每行中的null的列都需要額外的空間來標(biāo)識
  4. 對null 的處理時候,只能采用is null或is not null,而不能采用=、in、<、<>、!=、not in這些操作符號。如:where name!=’shenjian’,如果存在name為null值的記錄,查詢結(jié)果就不會包含name為null值的記錄

索引設(shè)計規(guī)范

單表索引建議控制在5個以內(nèi)

單索引字段數(shù)不允許超過5個
原因:字段超過5個時,實際已經(jīng)起不到有效過濾數(shù)據(jù)的作用了。這個原因還不是很理解?

建立組合索引,必須把區(qū)分度高的字段放在前面
原因:能夠更加有效的過濾數(shù)據(jù)

禁止在更新十分頻繁、區(qū)分度不高的屬性上建立索引
原因:
1.更新會變更B+樹,更新頻繁的字段建立索引會大大降低數(shù)據(jù)庫性能
2.“性別”這種區(qū)分度不大的屬性,建立索引是沒有什么意義的,不能有效過濾數(shù)據(jù),性能與全表掃描類似


SQL 規(guī)范

*禁止使用SELECT ,只獲取必要的字段,需要顯示說明列屬性
原因:
1.讀取不需要的列會增加CPU、IO、NET消耗
2.不能有效的利用覆蓋索引
3.使用SELECT *容易在增加或者刪除字段后出現(xiàn)程序BUG

禁止使用INSERT INTO t_xxx VALUES(xxx),必須顯示指定插入的列屬性
原因:容易在增加或者刪除字段后出現(xiàn)程序BUG

禁止使用屬性隱式轉(zhuǎn)換
原因:SELECT uid FROM t_user WHERE phone=13812345678 會導(dǎo)致全表掃描,而不能命中phone索引

禁止在WHERE條件的屬性上使用函數(shù)或者表達式
原因:SELECT uid FROM t_user WHERE from_unixtime(day)>='2017-02-15' 會導(dǎo)致全表掃描
正確的寫法是:SELECT uid FROM t_user WHERE day>= unix_timestamp('2017-02-15 00:00:00')

禁止負向查詢,以及%開頭的模糊查詢
原因:

  1. 負向查詢條件:NOT、!=、<>、!<、!>、NOT IN、NOT LIKE等,會導(dǎo)致全表掃描
  2. %開頭的模糊查詢,會導(dǎo)致全表掃描

禁止大表使用JOIN查詢,禁止大表使用子查詢
原因:會產(chǎn)生臨時表,消耗較多內(nèi)存與CPU,極大影響數(shù)據(jù)庫性能

禁止使用OR條件,必須改為IN查詢
原因:舊版本Mysql的OR查詢是不能命中索引的,即使能命中索引


業(yè)務(wù)規(guī)范

數(shù)據(jù)表,created_at, updated_at是必須字段, deleted_at根據(jù)業(yè)務(wù)是否需要軟刪除選擇性加入

代碼中如有寫SELECT, UPDATE, DELETE 等相關(guān)sql語句,sql關(guān)鍵字必須大寫

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 目錄 一、數(shù)據(jù)庫命令規(guī)范 二、數(shù)據(jù)庫基本設(shè)計規(guī)范 三、數(shù)據(jù)庫字段設(shè)計規(guī)范 四、索引設(shè)計規(guī)范 五、常見索引列建議 六...
    鮮人掌閱讀 1,056評論 0 0
  • 轉(zhuǎn) # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    呂品?閱讀 10,158評論 0 44
  • 一、數(shù)據(jù)庫命令規(guī)范 所有數(shù)據(jù)庫對象名稱必須使用小寫字母并用下劃線分割所有數(shù)據(jù)庫對象名稱禁止使用mysql保留關(guān)鍵字...
    為愛放棄一切閱讀 705評論 0 1
  • 一、基礎(chǔ)規(guī)范 第一條:必須使用InnoDB存儲引擎 解讀:支持事務(wù)、行級鎖、并發(fā)性能更好、CPU及內(nèi)存緩存頁優(yōu)化使...
    SangSir閱讀 218評論 0 0
  • 一、基礎(chǔ)規(guī)范 第一條:必須使用InnoDB存儲引擎 解讀:支持事務(wù)、行級鎖、并發(fā)性能更好、CPU及內(nèi)存緩存頁優(yōu)化使...
    guanguans閱讀 222評論 0 4

友情鏈接更多精彩內(nèi)容