电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

MySQL數據庫使用規范總結

瀏覽:5日期: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 數據庫
相關文章:
主站蜘蛛池模板: 山东集装箱活动房|济南集装箱活动房-济南利森集装箱有限公司 | 博客-悦享汽车品质生活 | 南京蜂窝纸箱_南京木托盘_南京纸托盘-南京博恒包装有限公司 | COD分析仪|氨氮分析仪|总磷分析仪|总氮分析仪-圣湖Greatlake | 医学动画公司-制作3d医学动画视频-医疗医学演示动画制作-医学三维动画制作公司 | 单螺旋速冻机-双螺旋-流态化-隧道式-食品速冻机厂家-广州冰泉制冷 | 紧急切断阀_气动切断阀_不锈钢阀门_截止阀_球阀_蝶阀_闸阀-上海上兆阀门制造有限公司 | 100国际学校招生 - 专业国际学校择校升学规划 | 艺术漆十大品牌_艺术涂料加盟代理_蒙太奇艺术涂料厂家品牌|艺术漆|微水泥|硅藻泥|乳胶漆 | 篷房[仓储-婚庆-展览-活动]生产厂家-江苏正德装配式帐篷有限公司 | 楼承板-开口楼承板-闭口楼承板-无锡海逵 | 智成电子深圳tdk一级代理-提供TDK电容电感贴片蜂鸣器磁芯lambda电源代理经销,TDK代理商有哪些TDK一级代理商排名查询。-深圳tdk一级代理 | 小程序开发公司_APP开发多少钱_软件开发定制_微信小程序制作_客户销售管理软件-济南小溪畅流网络科技有限公司 | 南京和瑞包装有限公司 | 药品仓库用除湿机-变电站用防爆空调-油漆房用防爆空调-杭州特奥环保科技有限公司 | 抖音短视频运营_企业网站建设_网络推广_全网自媒体营销-东莞市凌天信息科技有限公司 | 蜘蛛车-登高车-高空作业平台-高空作业车-曲臂剪叉式升降机租赁-重庆海克斯公司 | 超高频感应加热设备_高频感应电源厂家_CCD视觉检测设备_振动盘视觉检测设备_深圳雨滴科技-深圳市雨滴科技有限公司 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 微波消解仪器_智能微波消解仪报价_高压微波消解仪厂家_那艾 | 铝板冲孔网,不锈钢冲孔网,圆孔冲孔网板,鳄鱼嘴-鱼眼防滑板,盾构走道板-江拓数控冲孔网厂-河北江拓丝网有限公司 | 防伪溯源|防窜货|微信二维码营销|兆信_行业内领先的防伪防窜货数字化营销解决方案供应商 | 深圳品牌设计公司-LOGO设计公司-VI设计公司-未壳创意 | 道达尔润滑油-食品级润滑油-道达尔导热油-合成导热油,深圳道达尔代理商合-深圳浩方正大官网 | 旅游规划_旅游策划_乡村旅游规划_景区规划设计_旅游规划设计公司-北京绿道联合旅游规划设计有限公司 | 海德莱电力(HYDELEY)-无功补偿元器件生产厂家-二十年专业从事电力电容器 | 亿诺千企网-企业核心产品贸易 | 智慧食堂_食堂管理系统_食堂订餐_食堂消费系统—客易捷 | 铝板冲孔网,不锈钢冲孔网,圆孔冲孔网板,鳄鱼嘴-鱼眼防滑板,盾构走道板-江拓数控冲孔网厂-河北江拓丝网有限公司 | 伟秀电气有限公司-10kv高低压开关柜-高低压配电柜-中置柜-充气柜-欧式箱变-高压真空断路器厂家 | IIS7站长之家-站长工具-爱网站请使用IIS7站长综合查询工具,中国站长【WWW.IIS7.COM】 | 消泡剂-水处理消泡剂-涂料消泡剂-切削液消泡剂价格-东莞德丰消泡剂厂家 | 井式炉-台车式回火炉-丹阳市电炉厂有限公司 | 紫外线老化试验箱_uv紫外线老化试验箱价格|型号|厂家-正航仪器设备 | 青岛球场围网,青岛车间隔离网,青岛机器人围栏,青岛水源地围网,青岛围网,青岛隔离栅-青岛晟腾金属制品有限公司 | 奥因-光触媒除甲醛公司-除甲醛加盟公司十大品牌 | 安徽集装箱厂-合肥国彩钢结构板房工程有限公司 | 专业甜品培训学校_广东糖水培训_奶茶培训_特色小吃培训_广州烘趣甜品培训机构 | 经济师考试_2025中级经济师报名时间_报名入口_考试时间_华课网校经济师培训网站 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 沈阳缠绕包装机厂家直销-沈阳海鹞托盘缠绕包装机价格 |