您现在的位置:新闻首页>资本 > 程序员必会MySQL使用规范手册
程序员必会MySQL使用规范手册
mysql教程栏目介绍MySQL使用规范手册
更多相关免费学习:mysql教程(视频)
一个平台或系统随着时间的推移和用户量的增多,数据库操作往往会变慢;而在Java应用开发中数据库更是尤为重要,绝大多数情况下数据库的性能决定了程序的性能,如若前期埋下的坑越多到后期数据库就会成为整个系统的瓶颈;因此,更规范化的使用MySQL在开发中是不可或缺的。
一、MySQL数据库命名规范
1、数据库所有表前缀均使用项目名称首字母缩写;
2、数据库所有对象名称均使用小写字母,并且单词之间通过下划线、数据库所有对象名称禁止使用MySQL保留字及关键字,涉及到关键字的SQL查询需要将关键字用单引号括起来;
4、数据库所有对象名称不超过32个字符,并且命名要遵循见名知意原则;
5、数据库临时表必须以 pro_tmp_ 为前缀并且以日期 20190917 为后缀,备份表必须以 pro_bac 为前缀并以时间戳为后缀;(pro为项目名称首字母缩写)
6、数据库所有存储相同数据的列名和列类型必须保持一致。
二、MySQL数据库基本设计规范
1、若无特殊说明,建表时一律采用Innodb存储引擎。
选择合适的引擎可以提高数据库性能,如InnoDB和MyISAM,InnoDB和MyISAM是许多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定;
基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持;MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持以及外部键等高级数据库功能;
因此,其支持事务处理、支持外键、支持崩溃修复能力和并发控制是我们建表时首选的存储引擎。
2、数据库和表的字符集统一使用UTF8
数据库和表的字符集统一使用utf8,若是有字段需要存储emoji表情之类的,则将表或字段设置成utf8mb4;因为,utf8号称万国码,其无需转码、无乱码风险且节省空间,而utf8mb4又向下兼容utf8。
3、设计数据库时所有表和字段必须添加注释
使用Comment从句添加表和列的备注,或直接在数据库连接工具的注释栏添加注释,从项目开始就进行数据字典的维护。
使用Comment从句添加注释如:
-- 1、创建表: CREATE TABLE t1(id varchar2(32) primary key,name VARCHAR2(8) NOT NULL,age number); -- 2、添加表注释: Comment on table t1 is '个人信息'; -- 3、添加字段注释:s '姓名'; comment on column t1.age is '年龄';
使用数据库连接工具添加注释:
4、单个表的数据量大小控制在500万以内
尽量控制单表数据量的大小,建议控制在500万以内;500万并不是MySQL数据库的极限,但数据量太多不利于对表结构进行修改、备份和恢复数据,适当采用分库分表等手段来控制单表数据量的大小。
5、使用MySQL分区表需谨慎
分区是将一个表的数据按照某种方式,比如按照时间上的月份,分成多个较小的,更容易管理的部分,但是逻辑上仍是一个表;分区表在物理上表现为多个文件,在逻辑上仍表现为同一个表,需要谨慎选择分区键;跨分区查询效率可能会更低,建议使用物理分区表等方式管理大数据。
6、尽量满足冷热数据分离,减小表等宽度
MySQL限制每个表最多存储4096列,并且每一行数据的大小不超过65535字节,为了减少磁盘IO线程的开销,就要适当控制表的宽度,因为表越宽,把表装载进内存缓冲池时所占用的内存也就越大,就会消耗更多的IO线程;除此之外,为了保证热数据的内存缓存命中率,更有效的利用缓存,避免读入无用的冷数据,尽量把经常使用到的列放到同一个表中,避免不必要的关联操作。
7、建立预留字段需谨慎
部分友人在设计数据库表时,不仅设计了当前所需要的字段,而且还在其中留出几个字段作为备用。比方说,我设计了一个人员表(Person),其中已经添加了各种必要的字段,包括姓名(Name)、性别(Sex)、出生年月日(birthday)等等;
为了以防万一,比如之后可能Person 表会涉及到毕业院校、工作单位、是否婚配和相片等信息,于是就加入5个varchar2 型的字段,分别叫做Text1、Text2……Text5;这一手操作看似防范于未然,其实也并不见得,因为大量预留字段会浪费空间、预留字段不能做到见名知意、预留字段无法确认存储的数据类型且修改其字段类型还可能会造成锁表等问题。
针对此等情况可以参考以下两点解决方案:
如果数量很少,而且信息的性质与原表密切相关,那么就可以直接在原表上增加字段,并将相关的数据更新进去;
如果数量较大,或者并非是原表对象至关重要的属性,那么就可以新增一个表,然后通过键值连接起来;
8、数据库中禁止存储图片、文件等大的二进制数据
若往数据库表中存储文件,而文件通常很大,当数据库进行读取操作时,会进行大量的随机IO操作,大文件使得IO操作很耗时耗性能,造成短时间内数据量快速增长;所以,通常将图片、文件存储在文件服务器中,数据库只用于存储文件地址信息。
三、MySQL数据库字段设计规范
1、优先选择符合存储需要的最小的数据类型。
主要是考虑索引的性能,因为列的字段越大,建立索引时所需要的空间也越大,这样一页中能存储的索引节点的数量也就越少,在遍历时需要的IO次数也就越多,索引的性能也就越差。
2、避免使用TEXT、BLOB数据类型
避免使用TEXT和BLOB数据类型,其中最常见的TEXT类型可以存储64K数据,MySQL内存临时表不支持TEXT、BLOB这样的大数据类型,若查询中包含这样的数据,在执行排序等操作时就不能使用内存临时表,必须使用磁盘临时表执行操作;
TEXT和BLOB类型只能使用前缀索引(当索引是很长的字符序列时,这个索引将会很占内存,而且会很慢,这时候就会用到前缀索引了;所谓的前缀索引就是去索引的前面几个字母作为索引,但是要降低索引的重复率,所以我们还必须要判断前缀索引的重复率;),因为MySQL对索引字段长度是有限的,所以TEXT类型只能使用前缀索引,并且TEXT列上是不能有默认值的;
若需要使用,建议把BLOB或TEXT列分离到单独的的扩展表中,且查询时一定不要使用select *,只需取出必要的列即可。
3、避免使用ENUM枚举类型
修改ENUM 值需要使用ALTER 语句;
ENUM 类型的ORDER BY 操作效率低;
禁止使用数值作为ENUM 的枚举值。
4、所有列的默认值定义为NOT NULL
数据库所有为NULL 的列需要额外的空间来存储,因此会占用更多的空间;
数据库在进行比较和计算时需要对NULL 值做特别处理。
5、使用TIMESTAMP(4字节)或DATETIME(8字节)类型存储时间
TIMESTAMP 存储的时间范围为:1970-01-01 00:00:01 ~ 2038-01-19-03:14:07;
TIMESTAMP 占用4字节和INT相同,但可读性比INT 类型的高,若是超出TIMESTAMP 取值范围的则使用DATETIME 类型存储;
用字符串类型存储时间的缺点:无法使用日期函数进行比较计算、字符串存储占有更多的空间。
6、财务相关的金额类数据必须使用decimal 类型
精准浮点:decimal
非精准浮点:float、double
Decimal类型为精准浮点数,在计算时不会丢失精度;占有空间大小由定义的宽度决定,每4个字节可以存储9位数字,且小数点也要占有一个字节;另外,Decimal类型可用于存储比bigint更大的数据类型。
四、MySQL索引设计规范
1、每张表的索引数量不超过5个
索引可以增加查询效率,但同样也会降低插入和更新的效率,甚至有些情况下还会降低查询效率,因此并不是越多越好,要控制其数量。
2、每个Innodb 表必须有一个主键
Innodb 是一种索引组织表,其数据存储的逻辑顺序和索引的顺序是相同的;
每张表可以有多个索引,但表的存储顺序只能有一种,Innodb 是按照主键索引的顺序来组织表的,因此不要使用更新频繁的列、UUID、MD5、HASH和字符串列作为主键,这些列无法保证数据的顺序增长,主键建议使用自增ID 值。
3、尽量避免使用外键约束
不建议使用外键约束(foreign key),但一定要在表与表之间的关联键上建立索引;
外键虽然可以保证数据的参照完整性,但外键也会影响父表和子表的写操作从而降低性能,还会使得表更耦合,建议在业务端实现。
五、MySQL数据库SQL开发规范
1、建议使用预编译语句进行数据库操作
预编译语句可以重复使用,相同的SQL语句可以一次解析,多次使用,减少SQL编译所需要的时间,提高处理效率;此外,还可以有效解决动态SQL带来的SQL注入问题。
2、避免数据类型的隐式转换
隐式转换如:SELECT 1 + "1";数值型 + 字符型 的隐式转换有可能会导致索引失效,以及一些意想不到的结果等。
3、充分利用表中存在的索引
1)避免使用双%号的查询条件
如 WHERE first_name like '%James%',若无前置%,只有后置%,则执行SQL语句时会用到列上的索引,双%号则不会使用列上的索引。
2)一条SQL语句只能使用复合索引中的一列进行范围查询
例如有weight、age、sex三列的联合索引,在查询条件中有weight列的范围查询,则在age和sex列上的索引将不会被使用;因此,在定义联合索引时,若某列需要用到范围查询,则将该列放到联合索引的右侧。
3)使用not exists 代替not in
因为not in 在SQL语句中执行时会导致索引失效。
4、杜绝使用SELECT * ,必须使用SELECT <字段列表> 查询
因为使用SELECT * 查询会消耗更多的CPU、IO和网络宽带资源,并且查询时无法使用覆盖索引。
5、禁止使用不含字段列表的INSERT 语句
如:INSERT into table_name values ('1','2','3'); 改为带字段列表的INSERT 语句:INSERT into table_name('c1','c2','c3') values ('1','2','3');
6、避免使用子查询,可以把子查询优化为join 关联操作
但是,通常子查询在in 子句中,且子查询中为简单SQL(即不包含union、group by、order by、limit从句)时,才可以把子查询转化为join关联查询进行优化;
子查询性能差的原因:
子查询的结果集无法使用索引,通常子查询的结果集会被存储到临时表中,不论是内存临时表还是磁盘临时表都不会存在索引,所以查询性能会受到一定的影响;
由于子查询会产生大量的临时表也没有索引,所以会消耗过多的CPU和IO资源,产生大量的慢查询。
7、避免使用JOIN 关联太多表
1)在Mysql中,对于同一个SQL关联(join)多个表,每个join 就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大;
2)如果程序中大量的使用了多表关联的操作,同时join_buffer_size(MySQL允许关联缓存的个数)设置的也不合理的情况下,就容易造成服务器内存溢出的情况,就会影响服务器数据库性能的稳定性;
3)此外,对于关联操作来说,会产生临时表影响查询效率,而Mysql最多允许关联61个表,建议不超过5个;
8、对同一列对象进行or 判断时,使用in 替代or
in 的值只要涉及不超过500个,则in 操作可以更有效的利用索引,or 大多数情况下很少能利用到索引。
9、禁止使用order by rand() 进行随机排序
10、禁止在WHERE 从句中对列进行函数转换和计算
因为在WHERE 从句中对列进行函数转换或计算时会导致索引无法使用。
No:
where date(end_time)='20190101'
:
where end_time >= '20190101' and end_time < '20190102'
11、在明显不会有重复值时使用UNION ALL 而不是UNION
1)UNION 会把两个结果集的所有数据放到临时表中后再进行去重操作;
2)UNION ALL 不会再对结果集进行去重操作;
12、把复杂、较长的SQL 拆分为为多个小SQL 执行
1)大SQL在逻辑上比较复杂,是需要占用大量CPU 进行计算一条SQL语句;
2)在MySQL中,一条SQL 语句只能使用一个CPU 进行计算;
3)SQL拆分后可以通过并行执行来提高处理效率。
六、MySQL数据库行为规范
1、超过100万行数据的批量操作(update delete insert),分多次进行
大批量操作可能回造成严重的主从延迟;
binlog日志为row格式时会产生大量的日志;
避免产生大事物操作。
2、对于大表使用pt-online-schema-change 修改表结构
1)避免大表修改产生的主从延迟、避免在对表字段进行修改时进行锁表;
2)pt-online-schema-change 它首先会建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器;然后,把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉,其是把原来一个DDL操作,分解成多个小的批次执行。
3、禁止给程序使用的账号授予super 权限
当达到最大连接数限制时,还运行1个有super权限的用户连接super权限只能留给DBA处理问题的账号使用。
4、对于程序连接数据库账号,遵循权限最小原则
程序使用数据库账号只能在一个数据库下使用,且程序使用的账号原则上不授予drop 权限。
-
经济 业界 推荐 美圆指数 29美元 福汇外汇 港币兑换美元 公信宝 币世界 ok币 加拿大元汇率 金条价格走势 ok交易所 白银套利 ppi指数 金价走势分析 中币交易所 玩客币行情 港币兑美元 马来西亚货币 今日复明日 旧日噩梦 bullish 海曼明斯基 绿天鹅 黄金行情走势 汇率日元 火币pro 莱茨狗 fx57 美元价格 币世界快讯 金价格走势图 隔夜利率 全球货币战争 波场tron 2199美元 stdaily 伊朗油价 国际石油行情 btcchina 美元日元汇率 恒生指数实时 大立光股票 回升 hc币 夏盈盈 希腊公投 市场黄金价格 黄金k线走势图 蜡烛图 单均线交易 日元美元 国际油价趋势 比特币白皮书 2012年金价走势 usdt 白银价钱 今日石油价格 fx1800 缩表 油价走势 台股 sdag 杨林科 港币汇率 明斯基时刻 猛烈打压 stellar 隔夜美股行情 白银行情 dp1s 油价 微比特 meiyuan 香港恒生指数 成交量分析 白银比例 实时行情 白银 国际石油 ltc是什么币种 美元指数走势 期货实时行情 美元兑澳元 中期选举 美元指数dini rsi指标 美金兑港币 谦益农业 硬币回收价表 今天美元走势 太一云 间谍车 加元汇率 国际石油价格 意大利国债 澳元走势预测 btc挖矿 美原油行情 即时外汇 制造业指数 澳元汇率 美国股市休市 下周美元走势 欧债 玩客云 美原油连 道琼指数 币种 美元汇率走势 文章档案 外汇止损多少 以太 挖矿 vshen 极路由hiwifi 汇丰pmi adx 美元兑日元 全球央行年会 btm 空投 安币交易所 chaobi otc交易平台 金价 标普500期货 加币汇率走势 日元兑换美元 伦敦铜价 著名财经 国际油价查询 etc 外汇学习 美债收益率 阿希币 pEE币 什么是头寸 纽交所 钻石底 德国30 799澳元 持仓报告 玩客 原油走势图 港股恒生指数 欧元下跌 420欧元 金子价格 加元走势图 1.11111E+11 xrp 美元指数k线图 金价走势预测 最新黄金价格 铜价格走势图 黄金降价 汇率欧元 金针探底 原油成本 美元 strllar 泰奇猫 圈牌 金价走势 以太币 lme铜实时行情 eos价格走势 欧元兑美金 外汇基本知识 联邦基金利率 伦敦银走势图 基本面分析 空头回补 云鱼 py6是什么货币 rsi指标详解 265万澳元 国际油价格 gateio wti原油走势图 门罗币 白银价格走势 欧盟财长会议 外汇咨询 交叉盘 外汇初学 房价指数 cbt 比特股 ltc 隐私政策 石油危机 日圆汇率 英国股市指数 原油最新价格 行情报价 自动减支 黄金市场价 全球指数 imtoken 币投资 10美金 eos币价格 相对强弱指标 黄金年走势图 美原油 加元美元 虚拟币 值多少钱 国际油价 外汇哈里森 外汇交易分析 白银价格分析 日bi btcc 标准普尔500 wti原油价格 zbcom 和币 度宇宙 技术指标分析 全球股市指数 币久 白银价格趋势 克龙 银行回收硬币 hiwifi 贝尔链 美元兑换欧元 后座议员 黄金市场行情 德拉基讲话 UES 道琼斯k线图 美元对日元 k线图分析 恒生指数 英国脱欧时间 港股指数 比特币之父 bin 今日原油 jinjia 日经225指数 比特币价格 英镑汇率 742 大立光 外汇走势 上吊线 趣步APP被调查 肖野 理财三 铜走势图 艾达 吞阳 coinex 欧元美金 赵长鹏 法郎汇率 9g游戏 英国脱欧结果 硅谷bbs 俄罗斯火星人 铜价 什么叫头寸
-
朋友 放学 仅数 英格兰银行 招生 dragon k线图解读 btc行情 美国总统 姐姐 欧盟会议 欧美黄金 引而不发 顾比均线 俄罗斯火星人 退出 隔夜利率 投资性需求 比特币交易 货币狼烟 老赖 消防员 汽车业 1199元 黄金k线走势图 市场黄金价格 加拿大元汇率 美国原油 2599澳元 关于黄金交易 港元兑美元 蝴蝶币 纽币汇率 非美货币 日内交易者 港币美元汇率 白银对冲套利 日经225 即时外汇牌价 美伊关系 台湾股票查询 外汇止损多少 币世界快讯 国际油价格 513部队 以为 人说 提高 慈善 青年 遭遇 经济 兑美元 bullish xunleiyun sleepfx失效 港币兑换 欧元走势 相对强弱指标 标准普尔500 持仓报告 极路由hiwifi 空投 ok交易所 推荐 微博 侧脸 热情 一层 联手 欧洲 火锅 揭秘 化工 专业 总决赛 开业 取消 好酒 业界 国际石油 以太坊 马来币 什么是头寸 空头行情 黄金的价格 印度卢比 威比特 石油走势 南非兰特 瑞波币 账户银走势图 27亿美金 链克行情 币投资 欧元美金 外汇走势 比特币价格 恒生指数 欧元兑美金 美元指数k线图 成交量分析 油价走势 美元兑澳元 国际石油价格 杨林科 fx57 otc交易平台 2012年金价走势 间谍车 谦益农业 播控云 多好 欧冠 传销 2018 猫日 fashion 尽在 摄像头 5 考场 灵魂 房屋 更好 秦岭 骑行 瘦领型 突尼斯 75人 至少 经贸 效率 攻坚战 依然 地震 客户端 网售 中国特色 好不好 户型 下周美元走势 白银 绿天鹅 ppi指数 白银价格趋势 张思聪 港币汇率 什么是比特币 黄金行情走势 第六计 外汇学堂 黄金价格分析 欧债 黄金走势 币热度 早晨之星 财经要闻 一级市场 德国股票指数 bkex 加拿大元走势 美国油价 铜期货 马来西亚币 法郎汇率 wti原油价格 黄金市场行情 美元对日元 imtoken 港股指数 硅谷bbs 交叉盘 美元兑日元 制造业指数 即时外汇 虚拟币 白银价格走势 吞阳 中期选举 云鱼 比特币之父 hc币 以太 阿希币 ok币 糖果空投 贫富悬殊 军事 提问 明星 违规 日军 再添 批量生产 四型 沦丧 师生 拍卖 靓号 妻子 两男 打印机 夏天 一下 新增 中考 根据 依法 精神 顺序 家装 质量 电线 匹克 齐聚 上海 在的 这么 半裙 来源 连接 送医 多门 又讲 达州 40个 连衣裙 由于 可握 25日 斑点 电池 将于 高考 行业 体育用品 今天美元走势 明斯基时刻 btc 欧盟财长会议 著名财经 财经新闻 DCR 白银行情 黄金价格行情 澳元走势k线图 最新国际油价 塞浦路斯危机 掉期交易 金克拉泽 eunice 莱特币矿池 链克口袋 传产 挖比特币 澳元兑美元 菲律宾比索 环球股指汇总 pee 黄金白银价格 澳元汇率走势 加元 外汇风险管理 美金对港币 道指指数 bitebi 道琼斯工业
-
朋友 ok交易所 业界 港币兑美元 加拿大元汇率 希腊公投 美元兑日元 绿天鹅 ppi指数 恒生指数实时 29美元 dp1s 今日复明日 仅数 海曼明斯基 俄罗斯火星人 波场tron 推荐 513部队 2199美元 汇率日元 美元指数k线图 2012年金价走势 火锅 币世界 明细 印度卢比 极路由hiwifi fx57 ok币 jinjia 经济 黄金k线走势图 隔夜利率 玩客币行情 火币pro 美圆指数 攻坚战 1199元 金条价格走势 即时外汇牌价 币世界快讯 金价格走势图 btc挖矿 钻石底 有限公司 回升 stdaily 港币兑换美元 杨林科 宽松 发表声明 下周美元走势 fx1800 国际石油价格 你吗 市场黄金价格 金价走势分析 外汇趋势分析 19929日元 12334 持仓报告 油价走势 玩客云 首登 日本 白银价格趋势 福汇外汇 缩表 原油最新价格 meiyuan 间谍车 老赖 鲜 美原油行情 蜡烛图 意大利国债 bullish fx 道琼指数 空投 微比特 3号 创造 效率 体育用品 关于黄金交易 比特币挖矿机 门罗币 香港恒生指数 美元日元汇率 谦益农业 莱茨狗 当天 突尼斯 财务省 白银 w底形态 圈牌 日圆汇率 安币交易所 otc交易平台 永久 成鬼 3人 fashion 匹克 今日石油价格 瑞士货币 美国国债利率 铜价 zbcom 外汇走势 美原油连 英国股市指数 中币交易所 usdt 军事 强国 罪证 交警 处去 对比 核实 查询 今天美元走势 明斯基时刻 著名财经 欧债 g7集团 今日恒生指数 白银价格分析 coinex 后座议员 btcc 欧元兑美金 外汇止损多少 比特币白皮书 外汇学习 币种 最新黄金价格 全球货币战争 hc币 完全 靓号 胳膊 用户 发布 29日 房价指数 黄金行情走势 2599澳元 国际石油行情 伊朗油价 火币比特币 黄金市场行情 全球股市指数 基本面分析 黄金年走势图 cbt 国际油价格 金价 日元美元 btcchina 40年 驾校 慈善 着力点 又放 大立光股票 行情报价 港币汇率 隔夜美股行情 白银价钱 gasstation 黄金etf是什么 联邦基金利率 pEE币 原油走势图 台股 美元指数走势 硬币回收价表 美国股市休市 金子价格 驱逐舰 救援 草色 腾讯 搭载 代人 顺序 他来 普爱 国企 班主任 包括 白银套利 白银行情 拜登大胜 wti原油价格 德国30 eos币价格 伦敦银走势图 10美金 vshen 成交量分析 澳元走势预测 以太 阿希币 国际油价趋势 尽在 美元 地方 怎样 青年 外汇哈里森 国际油价 单均线交易 汇率欧元 什么是头寸 国际油价查询 今日日历 股市行情图 欧元美金 原油成本 港股恒生指数 外汇咨询 英国脱欧时间 金价走势预测 hiwifi 值多少钱 制造业指数 澳元汇率 拍卖 福州 获赔 选科分 总决赛 打我 网售 千万 汇丰pmi 猛烈打压 原油wti 美金兑港币 欧盟财长会议 黄金走势 DCR 瑞士法郎汇率 外汇交易头寸 币投资 标准普尔500 欧元下跌 恒生指数 外汇交易分析 虚拟币 空头回补 泰奇猫 太一云 公信宝 ism制造业指数 赢了 消防员 人用 揭秘 能上 多门 美国总统







