溫馨提示×

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

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

高性能可擴(kuò)展MySQL數(shù)據(jù)庫設(shè)計(jì)及架構(gòu)優(yōu)化 電商項(xiàng)目_1

發(fā)布時(shí)間:2020-03-30 14:05:06 來源:網(wǎng)絡(luò) 閱讀:3735 作者:yanfeilai528 欄目:MySQL數(shù)據(jù)庫

一 數(shù)據(jù)庫設(shè)計(jì)規(guī)范


1 命名規(guī)范 

所有數(shù)據(jù)庫對(duì)象名稱必須用小寫字母并下劃線分割

對(duì)象名稱禁止使用MySQL保留關(guān)鍵字

命名要做到見名識(shí)義,不超過32字節(jié)

臨時(shí)表必須tmp前綴 日期后綴

備份庫表bak前綴 日期后綴

所有存儲(chǔ)相同數(shù)據(jù)的列名和類型必須一致

2 數(shù)據(jù)庫基本設(shè)計(jì)規(guī)范

所有表必須用innodb引擎

數(shù)據(jù)庫和表字符集同意使用utf8(全存儲(chǔ)中文的可以使用gbk 或是gbk2312)

所有表和字段都使用comment加注釋

從一開始就進(jìn)行數(shù)據(jù)字典的維護(hù)

盡量控制單表數(shù)據(jù)量的大小 建議500萬以內(nèi)

謹(jǐn)慎使用MySQL分區(qū)表

盡量做到冷熱數(shù)據(jù)分離 減小表的寬度

禁止在表中建立預(yù)留字段

禁止在數(shù)據(jù)庫中存儲(chǔ)圖片 文件等二進(jìn)制數(shù)據(jù)

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

禁止從開發(fā)環(huán)境 測(cè)試環(huán)境連接生產(chǎn)環(huán)境的數(shù)據(jù)庫


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

限制每張表索引數(shù)量,建議單張表索引不超過5個(gè)

每個(gè)innodb表必須有一個(gè)主鍵,不適用頻繁更新的列為主鍵 不適用多留主鍵

常見索引留建議: 在select update delete語句中where從句中的列

包含在order by 、group by  distinct中的字段

多表連接的關(guān)聯(lián)列

如何選擇索引列的順序:

區(qū)分度最高的列放在聯(lián)合索引的最左側(cè)(盡量選主鍵)

字段小的列放在聯(lián)合索引的最左側(cè)

使用最頻繁的列放在聯(lián)合索引的左側(cè)

不建議使用外鍵約束,但是一定在表與表之間的關(guān)聯(lián)鍵上建立索引


4 數(shù)據(jù)庫字段設(shè)計(jì)規(guī)范

有限選擇符合存儲(chǔ)需要的最小的數(shù)據(jù)類型,

    比如講字符串轉(zhuǎn)化的數(shù)字類型存儲(chǔ)

對(duì)于非負(fù)數(shù)數(shù)據(jù)采用無符號(hào)×××進(jìn)行存儲(chǔ)( unsigned int)

避免使用text blob enum類型

盡量把列定義為not null

使用大datetime 或timestamp類型存儲(chǔ)時(shí)間

同財(cái)務(wù)相關(guān)的金額類數(shù)據(jù) 必須使用decimal類型


5 數(shù)據(jù)庫sql開發(fā)規(guī)范

建議使用預(yù)編譯語句進(jìn)行數(shù)據(jù)庫操作

避免使用雙%的查詢條件 如like %w%

應(yīng)該對(duì)以后的擴(kuò)展進(jìn)行考慮

程序連接

禁止使用select *

避免使用子查詢 可轉(zhuǎn)化為join操作

避免使用join關(guān)聯(lián)太多的表 建議不少過5個(gè)

減少同數(shù)據(jù)庫的交互次數(shù)

明顯不會(huì)有重復(fù)值是使用union all代替union

拆分復(fù)雜的大sql為多個(gè)小sql


6 數(shù)據(jù)庫操作行為規(guī)范

超100萬行的批量些操作 要分批多次進(jìn)行操作

對(duì)大表使用pt-online-schema-change修改表結(jié)構(gòu)

禁止為程序使用的賬號(hào)賦予super權(quán)限,遵循權(quán)限最小原則,不準(zhǔn)有drop權(quán)限


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

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

AI