日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL數據庫使用規范總結

瀏覽:37日期:2023-10-13 13:14:39

導讀:

關于MySQL數據庫規范,相信大家多少看過一些文檔。本篇文章給大家詳細分類總結了數據庫相關規范,從庫表命名設計規范講起,到索引設計規范,后面又給出SQL編寫方面的建議。相信這些規范適用于大多數公司,也希望大家都能按照規范來使用我們的數據庫,這樣我們的數據庫才能發揮出更高的性能。

關于庫:

1.【強制】庫的名稱必須控制在32個字符以內,英文一律小寫。

2.【強制】庫的名稱格式:業務系統名稱_子系統名。

3.【強制】庫名只能使用英文字母,數字,下劃線,并以英文字母開頭。

4.【強制】創建數據庫時必須顯式指定字符集,并且字符集只能是utf8或者utf8mb4。創建數據庫SQL舉例:Create database db1 default character set utf8;

5.【建議】臨時庫、表名以tmp_ 為前綴,并以日期為后綴,備份庫、表以 bak_ 為前綴,并以日期為后綴。

關于表

1.【強制】表和列的名稱必須控制在32個字符以內,表名只能使用字母、數字和下劃線,一律小寫。

2.【強制】表名要求模塊名強相關,同一模塊使用的表名盡量使用統一前綴。

3.【強制】創建表時必須顯式指定字符集為utf8或utf8mb4。

4.【強制】列名盡量不用關鍵字(如type,order等)。

5.【強制】創建表時必須顯式指定表存儲引擎類型,如無特殊需求,一律為InnoDB。

6.【強制】建表必須有comment。

7.【強制】對于超過100W行的大表進行alter table,必須經過DBA審核,并在業務低峰期執行,多個alter需整合在一起。

因為alter table會產生表鎖,期間阻塞對于該表的所有寫入,對于業務可能會產生極大影響。

8.【建議】建表時關于主鍵:表必須有主鍵

(1)強制要求主鍵為id,類型為int或bigint,且為auto_increment 建議使用unsigned無符號型。

(2)標識表里每一行主體的字段不要設為主鍵,建議設為其他字段如user_id,order_id等,并建立unique key索引。

因為如果設為主鍵且主鍵值為隨機插入,則會導致innodb內部page分裂和大量隨機I/O,性能下降。

9.【建議】核心表(如用戶表)必須有行數據的創建時間字段create_time和最后更新時間字段update_time,便于查問題。

10.【建議】表中所有字段盡量都是NOT NULL屬性,業務可以根據需要定義DEFAULT值。

因為使用NULL值會存在每一行都會占用額外存儲空間、數據遷移容易出錯、聚合函數計算結果偏差等問題。

11.【建議】中間表用于保留中間結果集,名稱必須以tmp_ 開頭。備份表用于備份或抓取源表快照,名稱必須以bak_開頭。中間表和備份表定期清理。

12.【示范】一個較為規范的建表語句:

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=’網站用戶基本信息’

關于索引

1.【強制】InnoDB表必須主鍵為id int/bigint auto_increment,且主鍵值禁止被更新。

2.【強制】InnoDB和MyISAM存儲引擎表,索引類型必須為BTREE。

3.【建議】主鍵的名稱以 pk_ 開頭,唯一鍵以 uniq_ 或 uk_ 開頭,普通索引以 idx_ 開頭,一律使用小寫格式,以字段的名稱或縮寫作為后綴。

4.【建議】單個表上的索引個數不能超過8個。

5.【建議】在建立索引時,多考慮建立聯合索引,并把區分度最高的字段放在最前面。如列userid的區分度可由select count(distinct userid)計算出來。

6.【建議】在多表join的SQL里,保證被驅動表的連接列上有索引,這樣join執行效率最高。

7.【建議】建表或加索引時,保證表里互相不存在冗余索引。對于MySQL來說,如果表里已經存在key(a,b),則key(a)為冗余索引,需要刪除。

SQL編寫

1.【強制】程序端SELECT語句必須指定具體字段名稱,禁止寫成 *。

2.【強制】程序端insert語句指定具體字段名稱,不要寫成insert into t1 values(…)。

3.【強制】除靜態表或小表(100行以內),DML語句必須有where條件,且使用索引查找。

4.【強制】where條件里等號左右字段類型必須一致,否則無法利用索引。

5.【強制】WHERE 子句中禁止只使用全模糊的LIKE條件進行查找,必須有其他等值或范圍查詢條件,否則無法利用索引。

6.【強制】索引列不要使用函數或表達式,否則無法利用索引。如where length(name)=’Admin’或where user_id+2=10023。

7.【建議】insert into…values(XX),(XX),(XX).. 這里XX的值不要超過5000個。值過多雖然上線很很快,但會引起主從同步延遲。

8.【建議】SELECT語句不要使用UNION,推薦使用UNION ALL,并且UNION子句個數限制在5個以內。因為union all不需要去重,節省數據庫資源,提高性能。

9.【強制】禁止跨db的join語句。

10.【建議】不建議使用子查詢,建議將子查詢SQL拆開結合程序多次查詢,或使用join來代替子查詢。

11.【建議】線上環境,多表join不要超過5個表。

12.【建議】在多表join中,盡量選取結果集較小的表作為驅動表,來join其他表。

13.【建議】批量操作數據時,需要控制事務處理間隔時間,進行必要的sleep。

14.【建議】事務里包含SQL不超過5個因為過長的事務會導致鎖數據較久,MySQL內部緩存、連接消耗過多等問題。

15.【建議】事務里更新語句盡量基于主鍵或unique key,如update … where id=XX;否則會產生間隙鎖,內部擴大鎖定范圍,導致系統性能下降,產生死鎖。

16.【建議】減少使用order by,和業務溝通能不排序就不排序,或將排序放到程序端去做。Order by、group by、distinct這些語句較為耗費CPU,數據庫的CPU資源是極其寶貴的。

17.【建議】order by、group by、distinct這些SQL盡量利用索引直接檢索出排序好的數據。如where a=1 order by b可以利用key(a,b)。

18.【建議】包含了order by、group by、distinct這些查詢的語句,where條件過濾出來的結果集請保持在1000行以內,否則SQL會很慢。

以上就是MySQL數據庫使用規范的詳細內容,更多關于MySQL使用規范的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩国产欧美在线播放| 中文字幕系列一区| 国产精品社区| 在线成人动漫av| 欧美午夜精品一区二区三区电影| 在线亚洲人成| 蜜桃精品在线| 美女亚洲一区| 性色av一区二区怡红| 亚洲欧美视频| 蜜桃久久久久久久| 日本一区中文字幕| 欧美日韩一区二区高清| 日韩手机在线| 国产精品v日韩精品v欧美精品网站| 免费在线亚洲欧美| 中文在线а√在线8| 欧美日韩视频网站| 国产韩日影视精品| 日韩中文字幕区一区有砖一区 | 亚洲欧美日本国产| 自拍自偷一区二区三区| 91在线成人| 精品视频一二| 日韩不卡视频在线观看| 欧美午夜不卡| 在线观看一区| 国产精品视频一区二区三区综合 | 午夜精品网站| 亚洲精品在线二区| 麻豆一区在线| 999国产精品永久免费视频app| 99在线精品免费视频九九视| 丝袜脚交一区二区| 日韩精品电影一区亚洲| 国产一区一一区高清不卡| 日韩中文影院| 亚洲一区二区三区中文字幕在线观看 | 日韩精品免费一区二区在线观看 | 日韩福利视频网| 国产一区二区三区四区大秀| 欧美日韩国产一区二区三区不卡| 亚洲一区日韩| 国产精品一国产精品k频道56| 97视频热人人精品免费| 婷婷精品进入| 欧美日韩在线精品一区二区三区激情综合 | 麻豆国产精品视频| 欧美 日韩 国产一区二区在线视频| 综合国产在线| 97精品国产| 亚洲精品免费观看| 日韩av二区| 亚洲欧洲美洲国产香蕉| 你懂的亚洲视频| 波多野结衣一区| 免费日韩一区二区三区| 一区二区亚洲精品| 国产精品一区高清| 国产麻豆久久| 久久精品99久久久| 在线日韩欧美| 国产精品主播| 国产精品美女| 高清久久精品| 中文字幕免费精品| 毛片在线网站| 日韩中文字幕无砖| 丝袜av一区| 欧美在线91| 欧美另类专区| 精品久久亚洲| 日本aⅴ免费视频一区二区三区| 色一区二区三区四区| 日韩欧美中文字幕一区二区三区| 九色porny丨国产首页在线| 国产日韩三级| 影音国产精品| 正在播放日韩精品| 国产色噜噜噜91在线精品| 亚洲激情中文在线| 国产成人精品一区二区三区在线| 中文字幕成人| 欧美在线影院| 精品三级在线观看视频| 中文字幕日韩亚洲| 欧美日韩精品在线一区| 欧美国产极品| 日本午夜免费一区二区 | 日韩av一级片| 中文精品在线| 日韩免费看片| 另类综合日韩欧美亚洲| 日本a口亚洲| 蜜臀av性久久久久蜜臀aⅴ四虎| 91精品亚洲| 中文字幕在线高清| 国产日韩一区| 欧美日韩1区| 亚洲精品免费观看| 亚洲在线一区| 亚洲精品一二三区区别| 久久久久亚洲| 电影亚洲精品噜噜在线观看| 麻豆一区二区三区| 欧美日韩在线精品一区二区三区激情综合 | 欧美午夜精彩| 国产va免费精品观看精品视频| 欧美精品国产一区| 日本中文字幕不卡| 亚洲狼人精品一区二区三区| 性欧美精品高清| 亚洲欧美高清| 亚洲视频播放| 国产一区二区高清| 日韩午夜av在线| 在线日韩一区| 亚洲高清激情| 婷婷激情综合| 国产精品腿扒开做爽爽爽挤奶网站| 日韩av首页| 99精品在线观看| 伊人久久av| 精品国模一区二区三区| 久久国产影院| 久久天堂精品| 激情综合网址| 国产手机视频一区二区| 免费中文字幕日韩欧美| 麻豆91精品| 亚洲日产国产精品| 97久久亚洲| 国产精品蜜月aⅴ在线| 国产精久久一区二区| 国产精品九九| 精品五月天堂| 视频在线不卡免费观看| 黄色网一区二区| 国产v日韩v欧美v| 吉吉日韩欧美| 日韩综合精品| 日韩亚洲在线| 日韩中文字幕一区二区高清99| 欧美日韩va| 欧美激情一区| 日韩欧美一区二区三区在线观看 | 在线看片日韩| 日韩精选在线| 国产欧美综合一区二区三区| 久久精品午夜| 神马午夜久久| 在线精品福利| 国产精品一站二站| 国产福利片在线观看| 欧美1级日本1级| 亚洲免费毛片| 精品伊人久久| 99精品在线| 亚洲开心激情| 久久99影视| 久久久久久久久99精品大| 亚洲免费婷婷| 日韩精品中文字幕一区二区| 国产精品亚洲综合在线观看| 国内精品伊人| 亚洲一区二区三区四区五区午夜 | 日本午夜大片a在线观看| 影音先锋国产精品| 国产三级一区| 日韩高清中文字幕一区二区| 免费精品视频最新在线| 国产乱人伦精品一区| 日韩欧美字幕| 蜜桃视频一区二区三区| 精品九九在线| 一区在线免费| 麻豆久久一区| 亚洲激情二区| 国产精品xvideos88| 欧美影院三区| 日本免费新一区视频| 亚洲精品国产嫩草在线观看| 最近国产精品视频| 国产一二在线播放| 亚洲久草在线| 91精品亚洲| 国产精品片aa在线观看| 国内亚洲精品| 国产精品久久| 亚洲综合丁香| 国产一区二区三区免费在线| 亚洲免费高清| 九九久久国产| 综合激情一区| 亚洲成人二区| 欧美经典一区| 亚洲丝袜啪啪| 久久国产直播| 国产精品片aa在线观看| 黄色成人精品网站|