mysql规范记录

<1>.索引

1.单表索引不超过5个;  
2.单个索引不超过5列;  
3.innodb主键推荐自增列;  
    主键不改被修改;  
    字符串不应该做主键;  
    若不指定主键,innodb会使用唯一且非空值索引代替;  
4.若是复合索引,区分度大的前置;  
5.核心sql优先考虑索引;  
6.区分度的的字段前置;  
7.避免冗余或重复索引:合理创建联合索引:index(a,b,c)相当于:index(a),index(a,b),index(a,b,c)  
8.不在低基数列建索引,如性别;  
9.不在索引列进行数学、函数运算;  
10.尽量不要使用外键;  
11.不使用%前导查询,如like"%xxx",无法使用索引;  
12.不使用反响查询,如not in、not like,无法使用索引;  
13.尽量要有主键。 

<2>.字段

1.禁止使用TEXT、BLOG类型;  
2.将字符转化为数字;  
3.使用TINYINT代替ENUM类型;  
4.字段长度尽量按照实际进行分配,不要随意给一个大容量;  
5.如果可能,所有字段尽量not null;  
6.使用unsigned存储非负整数;  
7.INT类型固定占用4个字节存储;  
8.使用TIMESTAMP存储时间;因为timestamp使用4字节,datetime使用8字节,同时timestamp具有自动复制以及自动更新的特性。  
9.禁止在数据库中存储明文密码;  

<3>.sql

1.禁止使用存储过程、触发器、视图等;让数据库做最擅长的事,降低业务耦合度;  
2.避免使用大表的join;  
3.避免数据库中进行数学运算,数学运算和逻辑判断,无法使用索引;  
4.减少与数据库的交互次数;  
5.拒绝大sql,拆分成小sql,充分使用query cache,充分利用多喝CPU.  
6.使用in 代替 or,in 的值不超过1000个;  
7.禁止使用order by rand();  因为使用order by rand() 会将数据从磁盘读取进行排序,耗费大量IO和CPU,可以再程序中获取一个rand值,然后通过数据库中获取对应的值。  
8.使用union all 而不是 union.  
9.禁止单条sql语句同时更新多个表(跨表更新);  
10.不使用select*;  
11.禁止使用test库;  

<4>.行为规范

1.禁止super权限应用账号存在;  
2.对单表的多次order必须合并为一次操作;  
3.不在业务高峰期批量更新、查询数据库。

----摘自京东内部规范。
2015-10-19 21:11

遇见超乎想象的自己!

319 声望
15 粉丝
0 条评论
推荐阅读
面试题-JVM-005. 双亲委派模型及其缺陷以及SPI和Tomcat的类加载
[链接][链接][链接]什么是双亲委派模型?双亲委派模型优势?-1. 使得 Java 类随着它的类加载器一起具有一种带有优先级的层次关系,从而使得基础类得到统一-2. 避免了多份同样字节码的加载双亲委派模型缺陷?举例说...

niewj阅读 100

一次偶然机会发现的MySQL“负优化”
今天要讲的这件事和上述的两个sql有关,是数年前遇到的一个关于MySQL查询性能的问题。主要是最近刷到了一些关于MySQL查询性能的文章,大部分文章中讲到的都只是一些常见的索引失效场合,于是我回想起了当初被那个...

骑牛上青山7阅读 1.7k评论 2

分布式高可用Mysql数据库Percona XtraDB Cluster 8.0 与 Proxysql 史上最详尽用法指南
PXC是Percona XtraDB Cluster的缩写,是 Percona 公司出品的免费MySQL集群产品。PXC的作用是通过mysql自带的Galera集群技术,将不同的mysql实例连接起来,实现多主集群。在PXC集群中每个mysql节点都是可读可写的...

apollo0084阅读 7.2k评论 2

MongoDB 插入时间与更新时间(create_time/update_time)
MongoDB 在数据库层面不能像 MySQL 一样设置自动创建 create_time/update_time,自动更新 update_time

qbit阅读 14k评论 2

Mysql索引覆盖
通常情况下,我们创建索引的时候只关注where条件,不过这只是索引优化的一个方向。优秀的索引设计应该纵观整个查询,而不仅仅是where条件部分,还应该关注查询所包含的列。索引确实是一种高效的查找数据方式,但...

京东云开发者2阅读 717

封面图
SegmentFault 思否技术周刊 Vol.70 — 深入 MySQL 实战
MySQL 软件采用了 GPL( GNU 通用公共许可证),由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了 MySQL 作为网站数据库。

Beverly2阅读 1.5k

封面图
MySQL 数据库索引技术原理初探
一本书 500 页的书,如果没有目录,直接去找某个知识点,可能需要找一会儿,但是借助前面的目录,就可以快速找到对应知识点在书的哪一页。这里的目录就是索引。

mylxsw1阅读 1.3k

遇见超乎想象的自己!

319 声望
15 粉丝
宣传栏