Mysql数据库性能
Mysql数据库设计规范
https://www.cnblogs.com/Luke-Me/p/8994432.html
我们在项目一开始的设计中,就要忙着考虑数据库的设计,表、字段、索引、sql等等,而在项目比较大型的时候,团队开发中由于多人同时进行,那么尽早的进行设计规范是项目开发非常关键的一步,那么关于数据库设计规范有哪些呢,包括以下6项:
复制代码
1.数据库命名规范
2.数据库基本设计规范
3.数据库索引设计规范
4.数据库字段设计规范
5.SQL开发规范
6.数据库操作行为规范
复制代码
接下来逐一详细介绍一下各个规范:
1.数据库命名规范:
1)所有数据库对象名称必须使用小写字母并用下划线分割(MySQL对大小写是敏感的)
2)禁止使用MySQL的保留关键字(比如:select user,from,age from tb_user 这时候识别不出from关键字,除非使用from
,反向单引号来区别)
3)数据库对象的命名最后能够见名识义,并且最好不要超过32个字符 ,例如:用户数据库 bd_userdb (百度_用户数据库) ,用户账号表 user_account
4)临时库表必须以tmp前缀并以日期为后缀,tmp_user_20180505 提供更加明确的表名
备份库,备份表必须以bak前缀并以日期为后缀,bak_userdb_20180504 bak_user_20180505
5)所有存储相同数据的列名和类型必须一致,例如:不同库表中的user_id(int unsigned not null),那么名称和类型必须是一致的,否则会产生查询效率降低等各种问题
2.数据库基本设计规范:
1)所有表必须使用InnoDB存储引擎。在MySQL5.6以后,innodb已经成为了默认存储引擎,它支持事务、行级锁,更好的恢复性,高并发下性能更好
2)数据库和表的字符集统一使用UTF-8。为了避免乱码、性能等问题
3)所有的表和字段都需要添加注释。使用comment添加备注信息,从一开始就进行数据库字典的维护
4)尽量控制单表数据量的大小,建议控制在500万行以内。使用历史数据归档、分库分表操作手段来控制数据量的大小
5)谨慎使用MySQL中的分区表。跨分区查询效率比较低,建议采用物理分表的方式来管理大数据
6)尽量做到冷数据分离,减小表宽度。字段太多的情况,尽量分表,将常用的放在一块,不常用的字段分到其他表中,有效减少磁盘的IO,保证热数据的缓存命中率
7)禁止在表中建立预留字段。由于无法预知预留字段的类型,后期对改字段进行修改会耗费很多资源,对表进行锁定等问题
8)禁止存储图片、文件等二进制文件,造成MySQL的性能影响。这些应该存储到专门的图片、文件服务器中,数据库中只存储对应的信息标识。
禁止在线上做数据库压力测试
禁止从开发环境、测试环境直连生成环境数据库
3.索引设计规范:
1)限制每张表索引的数量,建议单表索引不超过5个 。索引并不是越多越好,能提高查询效率,也能降低效率。应该根据实际情况来建立索引。
2)每个InnoDB表中必须有一个主键(唯一非空列)。不用使用频繁更新的列为主键,不使用MD5,UUID,HASH,字符串列作为主键。主键建议选择使用自增ID值
3)常见索引列建议:where从句中的列 order by、group by、distinct 中的字段,多表join的关联列,如果在字句中是单个列,那就单独索引,有多个列,那可以建立联合索引
4)如何选择索引列的顺序,区分度最高(比如主键列)的列,字段长度小,使用频繁的列放在联合索引的最左侧
5)避免建立冗余和重复的索引:index(a,b,c),index(a,b),index(a) 对于a就是重复索引
6)对于频繁的查询优先考虑使用覆盖索引:包含了所有查询字段的索引
7)尽量避免使用外键约束。外键会影响父表与子表的写操作从而降低性能
4.数据库字段设计规范:
1)优先选择符合存储需要的最小数据类型。例如:将字符串转化为数字存储
对于非负数优先选用无符号型来存储。例如:主键id,无符号比有符号多出一倍的存储空间。
有符号:signed int -2147483648 ~ 2147483647
无符号:unsigned int 0 ~ 4294967295
varchar(N) N代表的是字符数,而不是字节数,使用UTF8存储汉字varchar(255)=765个字节
过大的长度会消耗更多的内存,根据字段长度来分配内存。
2)避免使用Text、Blob数据类型,若需要使用,尽量分配到专门的扩展表中
3)避免使用Enum枚举类型。order by操作效率低。禁止使用数值作为ENum枚举值
4)尽可能把所有列定义为NOT NULL。索引NULL列需要更多的存储空间来保存。索引会失效。
5)避免使用字符串来存储日期时间,使用TIMESTAMP或DATATIME来存储时间
6)与财务相关的金额类型数据,必须使用Decimal类型。保证数据精度,计算时不丢失精度。
5.数据库SQL开发规范:
1)建议使用预编译语句进行数据库操作。只传参数,比传递sql更加高效,相同语句一次解析之后,多次使用,节约sql解析的成本,提高处理效率。
2)避免数据类型的隐式转换。隐式转换导致索引失效,一般在where字句条件中出现的类型转换,导致了索引失效。
3)合理利用已存在索引,而不是盲目添加索引。
避免使用双%的查询条件:like '%123%',只要出现前缀%,索引失效。
一个SQL只能利用到复合索引的一列进行范围查询,若联合索引 index(a,b,c) 对a进行范围查询,那么b和c将失效,应当将a放到最右侧
使用left join 或 not exists 来优化 not in 操作,not in会使索引失效
4)程序连接不同数据库时应该使用不同的账号,禁止跨库查询
5)禁止使用 select * 必须使用 select 查询,消耗过多的IO和cpu以及网络带宽资源
6)禁止使用不含字段的insert 语句,为了减少表结构的变更带来的影响:insert into table values('a','b','c'); 应当指明要插入的列,insert into table(c1,c2,c3) values('a','b','c');
7)避免使用子查询,可以将子查询优化为join操作:子查询都会创建临时表,占用cpu和io资源,子查询结果集无法使用索引。
8)避免使用join关联太多的表:
每关联一张表,多占用一部分内存(join_buffer_size)
会产生临时表操作,影响查询效率
MySQL最多允许关联61张表,建议不超过5张表
9)减少同数据库的交互次数
10)使用in代替or。in的值不超过500个,in可以有效使用索引,or不行。
11)禁止使用order by rand() 进行随机排序,这个操作对性能有很大影响,尽量通过程序来得到随机值再从数据库中获取数据。
12)禁止在where从句中对列进行函数转换和计算,造成索引的失效。where data(createtime) = '2018-01-01' ,尽量在程序中进行计算
13)在明显不会出现重复值的时候使用union all 而不是union。union会先加载所有数据到临时表中然后去重,而union all不会去重。
14)拆分复杂的大SQL成多个小SQL。并行执行小SQL来提高处理效率
6.数据库操作行为规范:
1)超过100万行的批量写操作,要分批多次进行操作:
大批量操作可能造成严重的主从延迟问题
binlog日志为row格式时,胡产生大量的日志,造成资源不足
避免产生大事务的操作
2)对于大表使用pt-online-schema-change工具来修改表结构。过程是:先创建新表,然后复制旧表数据到新表,将新表名称改成旧表名称,最后删除旧表
3)禁止为程序使用的账号赋予super超管权限
4)对于程序连接数据库账号,遵循权限最小的原则。程序使用数据库支行和只能在一个DB下使用,不准跨库,程序使用的账号原则上不准有drop权限
以上就是MySQL的一些设计规范,当然不是说一定要遵循以上的原则,具体视实际应用场景而定,通过DBA指导来指定原则。
本文原创,转载请标注出处:http://www.cnblogs.com/Luke-Me/p/8994432.html
Mysql数据库性能的更多相关文章
- 优化MySQL数据库性能的八大方法
本文探讨了提高MySQL 数据库性能的思路,并从8个方面给出了具体的解决方法. 1.选取最适用的字段属性 MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就 ...
- mysql数据库性能优化(包括SQL,表结构,索引,缓存)
优化目标减少 IO 次数IO永远是数据库最容易瓶颈的地方,这是由数据库的职责所决定的,大部分数据库操作中超过90%的时间都是 IO 操作所占用的,减少 IO 次数是 SQL 优化中需要第一优先考虑,当 ...
- MySQL 数据库性能优化之索引优化
接着上一篇 MySQL 数据库性能优化之表结构,这是 MySQL数据库性能优化专题 系列的第三篇文章:MySQL 数据库性能优化之索引优化 大家都知道索引对于数据访问的性能有非常关键的作用,都知道索引 ...
- MySQL数据库性能优化
mysql查询优化: 1.新增字段索引,查询时若使用到or关键字,则两个字段都需建立索引才能生效 2.sql语句包含子查询,mysql会创建临时表查询结束后删除,影响效率,所以应尽可能使用join替代 ...
- MySQL数据库性能优化专题
摘录: 书:<MySQL性能调优与架构设计> 一个系列: (按顺序排一下) MySQL 数据库性能优化之缓存参数优化 http://isky000.com/database/mysql-p ...
- MySQL 数据库性能优化之缓存参数优化
在平时被问及最多的问题就是关于 MySQL 数据库性能优化方面的问题,所以最近打算写一个MySQL数据库性能优化方面的系列文章,希望对初中级 MySQL DBA 以及其他对 MySQL 性能优化感兴趣 ...
- MySQL数据库性能优化:表、索引、SQL等
一.MySQL 数据库性能优化之SQL优化 注:这篇文章是以 MySQL 为背景,很多内容同时适用于其他关系型数据库,需要有一些索引知识为基础 优化目标 减少 IO 次数IO永远是数据库最容易瓶颈的地 ...
- MySQL 数据库性能调优
MySQL 数据库性能调优 MySQL性能 最大数据量 最大并发数 优化的范围有哪些 存储.主机和操作系统方面: 应用程序方面: 数据库优化方面: 优化维度 数据库优化维度有四个: 优化选择: 数据库 ...
- MySQL数据库性能优化与监控实战(阶段四)
MySQL数据库性能优化与监控实战(阶段四) 作者 刘畅 时间 2020-10-20 目录 1 sys数据库 1 2 系统变量 1 3 性能优化 1 3.1 硬件层 1 3.2 系统层 1 3.3 软 ...
- 浅谈MySQL 数据库性能优化
MySQL数据库是 IO 密集型的程序,和其他数据库一样,主要功能就是数据的持久化以及数据的管理工作.本文侧重通过优化MySQL 数据库缓存参数如查询缓存,表缓存,日志缓存,索引缓存,innodb缓存 ...
随机推荐
- SQLServer2008 在where条件中使用CASE WHEN
create table #temp( id int identity(1,1), name varchar(20), startYear int, startMonth in ...
- 前端性能优化---DOM操作
小结 1缓存DOM对象 场景:缓存DOM对象的方式也经常被用在元素的查找中,查找元素应该是DOM操作中最频繁的操作了,其效率优化也是大头.在一般情况下,我们会根据需要,将一些频繁被查找的元素缓存起来, ...
- 易企CMS模板调用标签列表
格式化URL formaturl 参数:type (生成URL类型) 可选值:article,product,category,catalog,comment参数:siteurl (生成URL网站地址 ...
- 1.0 windows10系统安装步骤(1)
1.0 windows10系统安装步骤(1) 根据自己对笔记本系统的折腾,为了方便他人系统的安装,故总结笔记本系统的安装步骤 目录: 1.0 [windows10系统安装步骤(1)] 2.0 Linu ...
- dubbo之结果缓存
结果缓存,用于加速热门数据的访问速度,Dubbo提供声明式缓存,以减少用户加缓存的工作量. lru 基于最近最少使用原则删除多余缓存,保持最热的数据被缓存. threadlocal 当前线程缓存,比如 ...
- VC维与DNN的Boundary
原文链接:解读机器学习基础概念:VC维来去 作者:vincentyao 目录: 说说历史 Hoeffding不等式 Connection to Learning 学习可行的两个核心条件 Effecti ...
- mvc登录授权特性
public class CommonAuthorize : AuthorizeAttribute { protected override bool AuthorizeCore(HttpContex ...
- vue路由中的 Meta
在项目中肯定有这样的需求,那就是在某个页面的时候,顶部展示 现在当前的页面路径,如下图: 这个在vue中其实很好实现. 首先出现这个肯定是相对应不同的页面,也就是说对应不同的路由,我们在定义路由的时候 ...
- 洛谷P1996 约瑟夫问题【队列】
题目背景 约瑟夫是一个无聊的人!!! 题目描述 n个人(n<=100)围成一圈,从第一个人开始报数,数到m的人出列,再由下一个人重新从1开始报数,数到m的人再出圈,--依次类推,直到所有的人都出 ...
- 48.Query DSL
主要知识点 1.Query DSL的理解及基本语法 2.如何组合多个搜索条件 bool 一.Query DSL的理解 Query DSL的查询形式如下: GET /_search { &quo ...