您好,登錄后才能下訂單哦!
tmp_
為前綴,并以日期為后綴,備份庫、表以
bak_
為前綴,并以日期為后綴。【強制】表和列的名稱必須控制在32個字符以內,表名只能使用字母、數字和下劃線,一律小寫。
【強制】表名要求模塊名強相關,同一模塊使用的表名盡量使用統一前綴。
【強制】創建表時必須顯式指定字符集為utf8或utf8mb4。
【強制】列名盡量不用關鍵字(如type,order等)。
【強制】創建表時必須顯式指定表存儲引擎類型,如無特殊需求,一律為InnoDB。
【強制】建表必須有comment。
【強制】對于超過100W行的大表進行alter table,必須經過DBA審核,并在業務低峰期執行,多個alter需整合在一起。
因為alter table會產生表鎖,期間阻塞對于該表的所有寫入,對于業務可能會產生極大影響。
【建議】建表時關于主鍵:表必須有主鍵
(1)強制要求主鍵為id,類型為int或bigint,且為auto_increment 建議使用unsigned無符號型。
(2)標識表里每一行主體的字段不要設為主鍵,建議設為其他字段如user_id,order_id等,并建立unique key索引。
因為如果設為主鍵且主鍵值為隨機插入,則會導致innodb內部page分裂和大量隨機I/O,性能下降。
【建議】核心表(如用戶表)必須有行數據的創建時間字段create_time和最后更新時間字段update_time,便于查問題。
【建議】表中所有字段盡量都是NOT NULL屬性,業務可以根據需要定義DEFAULT值。
因為使用NULL值會存在每一行都會占用額外存儲空間、數據遷移容易出錯、聚合函數計算結果偏差等問題。
【建議】中間表用于保留中間結果集,名稱必須以
tmp_
開頭。備份表用于備份或抓取源表快照,名稱必須以
bak_
開頭。中間表和備份表定期清理。
【示范】一個較為規范的建表語句:
mysql">CREATE TABLE user_info (
`id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '自增主鍵',
`user_id` bigint(11) NOT NULL COMMENT '用戶id',
`username` varchar(45) NOT NULL COMMENT '真實姓名',
`email` varchar(30) NOT NULL COMMENT '用戶郵箱',
`nickname` varchar(45) NOT NULL COMMENT '昵稱',
`birthday` date NOT NULL COMMENT '生日',
`sex` tinyint(4) DEFAULT '0' COMMENT '性別',
`short_introduce` varchar(150) DEFAULT NULL COMMENT '一句話介紹自己,最多50個漢字',
`user_resume` varchar(300) NOT NULL COMMENT '用戶提交的簡歷存放地址',
`user_register_ip` int NOT NULL COMMENT '用戶注冊時的源ip',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創建時間',
`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改時間',
`user_review_status` tinyint NOT NULL COMMENT '用戶資料審核狀態,1為通過,2為審核中,3為未通過,4為還未提交審核',
PRIMARY KEY (`id`),
UNIQUE KEY `uniq_user_id` (`user_id`),
KEY `idx_username`(`username`),
KEY `idx_create_time_status`(`create_time`,`user_review_status`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='網站用戶基本信息'
pk_
開頭,唯一鍵以
uniq_
或
uk_
開頭,普通索引以
idx_
開頭,一律使用小寫格式,以字段的名稱或縮寫作為后綴。免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。