您好,登錄后才能下訂單哦!
導讀:?
關于MySQL數據庫規范,相信大家多少看過一些文檔。本篇文章給大家詳細分類總結了數據庫相關規范,從庫表命名設計規范講起,到索引設計規范,后面又給出SQL編寫方面的建議。相信這些規范適用于大多數公司,也希望大家都能按照規范來使用我們的數據庫,這樣我們的數據庫才能發揮出更高的性能。
tmp_
為前綴,并以日期為后綴,備份庫、表以 bak_
為前綴,并以日期為后綴。【建議】建表時關于主鍵:表必須有主鍵
(1)強制要求主鍵為id,類型為int或bigint,且為auto_increment 建議使用unsigned無符號型。
(2)標識表里每一行主體的字段不要設為主鍵,建議設為其他字段如user_id,order_id等,并建立unique key索引。
因為如果設為主鍵且主鍵值為隨機插入,則會導致innodb內部page分裂和大量隨機I/O,性能下降。
tmp_
開頭。備份表用于備份或抓取源表快照,名稱必須以bak_
開頭。中間表和備份表定期清理。【示范】一個較為規范的建表語句:
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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。