亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > MySQL數據庫使用規(guī)范總結

MySQL數據庫使用規(guī)范總結

熱門標簽:許昌外呼增值業(yè)務線路 宜賓全自動外呼系統廠家 申請400電話電話價格 地圖標注客戶付款 石家莊400電話辦理公司 新鄉(xiāng)智能外呼系統好處 廣東400企業(yè)電話申請流程 咸陽防封電銷卡 臨沂做地圖標注

導讀:

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

關于庫:

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

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

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

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

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

關于表

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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 '創(chuàng)建時間', `update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改時間', `user_review_status` tinyint NOT NULL COMMENT '用戶資料審核狀態(tài),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.【建議】在建立索引時,多考慮建立聯合索引,并把區(qū)分度最高的字段放在最前面。如列userid的區(qū)分度可由select count(distinct userid)計算出來。

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

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

SQL編寫

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

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

3.【強制】除靜態(tài)表或小表(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不需要去重,節(jié)省數據庫資源,提高性能。

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

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

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

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

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

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

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

16.【建議】減少使用order by,和業(yè)務溝通能不排序就不排序,或將排序放到程序端去做。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數據庫使用規(guī)范的詳細內容,更多關于MySQL使用規(guī)范的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • MySQL 使用規(guī)范總結
  • 超詳細MySQL使用規(guī)范分享
  • 老鳥帶你開發(fā)專業(yè)規(guī)范的MySQL啟動腳本
  • MySQL開發(fā)規(guī)范與使用技巧總結
  • mysql數據庫開發(fā)規(guī)范【推薦】
  • MySQL數據庫命名規(guī)范及約定
  • Mysql建表與索引使用規(guī)范詳解
  • MYSQL 數據庫命名與設計規(guī)范
  • 專業(yè)級的MySQL開發(fā)設計規(guī)范及SQL編寫規(guī)范

標簽:北京 合肥 鎮(zhèn)江 鷹潭 臺灣 日照 阜新 貴州

巨人網絡通訊聲明:本文標題《MySQL數據庫使用規(guī)范總結》,本文關鍵詞  MySQL,數據庫,使用,規(guī)范,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL數據庫使用規(guī)范總結》相關的同類信息!
  • 本頁收集關于MySQL數據庫使用規(guī)范總結的相關信息資訊供網民參考!
  • 推薦文章
    成人影院一区二区三区| 色综合久久天天综合| 亚洲第一视频在线播放| 久久久久久久男人的天堂| 成人免费观看网欧美片| 日韩中文字幕在线亚洲一区| 国产美女在线观看| 日韩免费在线视频| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 99久久精品国产国产毛片 | 亚洲天堂免费| 亚飞与亚基在线观看| 国产麻豆精品视频| 欧美激情一区二区三区在线| 日韩中文字幕一区二区不卡| 99久久精品国产麻豆| 日韩男人天堂| 日韩中文字幕在线观看视频| 美女免费精品视频在线观看| 99色视频在线| 99热精品在线| 97视频免费在线观看| 精品视频在线看 | 夜夜操网| 精品国产一级毛片| 国产成人女人在线视频观看| 国产美女在线观看| 日韩中文字幕在线观看视频| 一级片免费在线观看视频| 国产网站麻豆精品视频| 免费一级生活片| 日韩中文字幕在线观看视频| 韩国三级视频网站| 四虎影视久久久| 亚洲女初尝黑人巨高清在线观看| 九九精品久久| 国产一区二区精品久久91| 九九九在线视频| 麻豆系列 在线视频| 成人免费观看视频| 91麻豆国产| 国产一区免费观看| 99久久网站| 欧美激情一区二区三区视频 | 日本免费看视频| 免费一级片在线| 日本免费区| 亚洲 激情| 日韩中文字幕在线观看视频| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产一区二区精品久| 久久99爰这里有精品国产| 亚洲 男人 天堂| 欧美激情一区二区三区在线| 四虎影视库国产精品一区| 国产综合91天堂亚洲国产| 国产网站在线| 毛片高清| 国产精品自拍一区| 精品国产一区二区三区久久久蜜臀 | 精品国产一区二区三区久久久蜜臀 | 精品国产亚一区二区三区| 精品国产一区二区三区久久久蜜臀| 在线观看导航| 中文字幕97| 日本免费看视频| 尤物视频网站在线| 亚洲第一视频在线播放| 国产一区二区精品尤物| 一级女性全黄久久生活片| 999精品影视在线观看| 亚洲 激情| 四虎影视库国产精品一区| 精品在线观看一区| 久久国产精品只做精品| 国产精品自拍一区| 91麻豆精品国产自产在线 | 欧美大片aaaa一级毛片| 四虎影视久久久| 韩国三级视频网站| 亚欧视频在线| 国产成人啪精品视频免费软件| 久久久久久久免费视频| 日韩在线观看视频免费| 国产成人精品影视| 欧美另类videosbestsex久久| 久久99青青久久99久久| 久久精品店| 999精品在线| 日韩中文字幕一区二区不卡| 成人高清视频在线观看| 欧美18性精品| 99热精品在线| 日韩中文字幕在线观看视频| 国产成人精品在线| 精品视频在线观看一区二区| 999久久久免费精品国产牛牛| 中文字幕Aⅴ资源网| 成人高清视频免费观看| 精品国产亚一区二区三区| 中文字幕Aⅴ资源网| 一级片片| 日日日夜夜操| 99久久精品国产高清一区二区 | 成人影院一区二区三区| 精品在线视频播放| 国产成人精品影视| 午夜久久网| 成人免费观看的视频黄页| 欧美一区二区三区性| 成人免费一级毛片在线播放视频| 九九久久99综合一区二区| 精品久久久久久影院免费| 亚洲 激情| 日韩在线观看免费完整版视频| 亚洲 国产精品 日韩| 韩国毛片免费大片| 日本免费看视频| 国产网站免费视频| 国产综合成人观看在线| 欧美另类videosbestsex高清| 午夜激情视频在线观看| 天天做日日干| 二级片在线观看| 99久久精品国产麻豆| 九九免费高清在线观看视频| 91麻豆精品国产综合久久久| 国产一区二区精品久久| 精品在线免费播放| 国产韩国精品一区二区三区| 欧美电影免费| 欧美另类videosbestsex| 久久国产精品只做精品| 韩国毛片 免费| 日本免费乱人伦在线观看 | 精品视频一区二区| 99久久精品国产国产毛片 | 日日夜夜婷婷| 九九精品久久| 99色视频在线| 九九热精品免费观看| 亚洲wwwwww| 久久99这里只有精品国产| 日本免费乱人伦在线观看 | 欧美激情一区二区三区在线播放| 精品久久久久久中文| 精品视频在线观看一区二区三区| 欧美激情在线精品video| 精品国产一区二区三区久久久蜜臀 | 久久99这里只有精品国产| 成人免费观看视频| 国产一区二区精品| 日日夜夜婷婷| 深夜做爰性大片中文| 日本特黄特色aa大片免费| 成人a级高清视频在线观看| 麻豆网站在线看| 午夜欧美福利| 999精品在线| 一级片片| 亚欧乱色一区二区三区| 国产不卡福利| 国产一区二区精品| 日本伦理片网站| 日韩在线观看视频免费| 精品国产亚洲人成在线| 中文字幕一区二区三区精彩视频| 国产91精品系列在线观看| 亚洲精品影院一区二区| 天天做人人爱夜夜爽2020| 精品国产一区二区三区久久久狼 | 天天做日日爱夜夜爽| 夜夜操网| 欧美一区二区三区在线观看| 99色吧| 成人免费一级毛片在线播放视频| 日韩字幕在线| 久久成人亚洲| 国产高清在线精品一区a| 日本在线不卡免费视频一区| 精品国产一区二区三区久久久蜜臀| 香蕉视频三级| 久久99这里只有精品国产| 亚洲 欧美 成人日韩| 欧美a级片视频| 午夜激情视频在线播放| 亚洲精品影院| 久久久久久久男人的天堂| 韩国毛片免费大片| 天天做日日爱夜夜爽| 色综合久久天天综合绕观看| 午夜欧美成人香蕉剧场| 日本特黄特色aa大片免费| 亚洲 男人 天堂| 欧美另类videosbestsex久久| 91麻豆精品国产自产在线 | 91麻豆精品国产综合久久久| 日韩专区亚洲综合久久| 精品视频在线观看视频免费视频 | 日韩avdvd|