SQL编写要求

关于库

1.【强制】库的名称必须控制在32个字符以内,只能使用英文字母、数字和下划线,建议以英文字母开头。

2.【强制】库名中英文律小写,不同单词采用下划线分割。须见名知意。

3.【强制】库的名称格式:业务系统名称子系统名。

4.【强制】库名禁止使用关键字(如type,order等)。

5.【强制】创建数据库时必须显式指定字符集,并且字符集只能是utf8或者utf8mb4。

创建数据库SQL举例: CREATE DATABASE crm_fund DEFAULT CHARACTER SET ‘utf8';

6.【建议】对于程序连接数据库账号,遵循权限最小原则使用数据库账号只能在一个DB下使用,不准跨库。程序使用的账号原则上不准有drop权限。

7.【建议】临时库以tmp为前缀,并以曰期为后缀;备份库以bak为前缀,并以日期为后缀。

关于表、列

1.【强制】表和列的名称必须控制在32个字符以内,表名只能使用英文字母、数字和下划线,建议以英文字开头。

2.【强制】表名、列名一律小写,不同单词采用下划线分割。须见名知意。

3.【强制】表名要求有模块名强相关,同一模块的表名尽量使用统一前缀。比如: crm_fund_item

4.【强制】创建表时必须显式指定字符集为utf8或utf8mb4。

5.【强制】表名、列名禁止使用关键字(如type,order等)。

6.【强制】创建表时必须显式指定表存储引擎类型。如无特殊需求,一律为InnoDB。

7.【强制】建表必须有comment。

8.【强制】字段命名应尽可能使用表达实际含义的英文单词或缩写。如:公司ID,不要使用corporation_id,用corp_id即可。

9.【强制】布尔值类型的字段命名为is_描述。如member表上表示是否为enabled的会员的字段命名为is_enabled。

10.【强制】禁止在数据库中存储图片、文件等大的二进制数据通常文件很大,短时间内造成数据量快速增长,数据库进行数据库读取时,通常会进行大量的随机 IO操作文件很大时,lo操作很耗时。通常存储于文件服务器,数据库只存储文件地址信息。

11.【建议】建表时关于主键:表必须有主链

(1)强制要求主键为id,类型为int或bigint,且为auto_increment建议使用unsigned无符号型。

⑵标识表里每一行主体的字段不要设为主键,建议设为其他字段如user_id,order_id等,并建立unique k索引。因为如果设为主键且主键值为随机插入,则会导致innodb内部页分裂和大量随机I/O,性能下降。

12.【建议】核心表(如用户表)必须有行数据的创建时间字段(create_time)和最后更新时间字段(update_time),便于查问题。

13.【建议】表中所有字段尽量都是NOT NULL属性,业务可以根据需要定义DEFAULT值。

13.【建议】表中所有字段尽量都是NOT NULL属性,业务可以根据需要定义DEFAULT值。 因为使用NULL值会存在每一行都会占用额外存储空间、数据迁移容易出错、聚合函数计算结果偏差等问题。

14.【建议】所有存储相同数据的列名和列类型必须一致(一般作为关联列,如果查询时关联列类型不一致会自动进行数据类型隐式转换,会造成列上的索引失效,导致查询效率降低)。 15.【建议】中间表(或临时表)用于保留中间结果集,名称以tmp开头。 备份表用于备份或抓取源表快照,名称以bak开头。中间表和备份表定期清理。

16.【示池】一个较为规范的建表语句:

`CREATE TABLE user info (`
	`id int unsigned NOT NULL AUTO_INCREIENT CONMENT '自增主键',`
	`user_id bigint(11) NOT NULL COMMENT '用户id',`
	`username varchar(45) NOT NULL COMMENT '真实姓名处'`
	`email varchar(38) NOT NULL COMMENT '用户他箱',`
	`nickname varchar(45) NOT NULL COM1MIENT '呢称',` 
	`birthday date NOT NULL CCKMENT '生日',`
	`sex tinyint(4) DEFAULT 0 COMMENT '性别',`
	`short_introduce varchar (15G) DEFAULT NULL COMMENT '一句话介绍自已,最多50个汉子',`
	`user_resume varchar(380) NOT NULL COMMENT '用户提交的简历夺放地址',`
	`user_registerip int NOT NULL COMMENT '用尸注册时的源ip',`
	`create time tinestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`
	`update_time tinestamp 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_usernane(username),`
	`KEY idx_create_time_status(create_time, user_review_status)`
`) ENGINE = InnoDB DEFAULT CHARSET = utf8 COMMENT = '网站用户基本信息'`

关于索引:

1.【强制】lnnoDB表必须主键为id int/bigint auto_increment,且主键值禁止被更新。

2.【强制】InnoDB和MylSAM存储引擎表,索引类型必须为BTREE。

3.【建议】主键的名称以pk开头,唯一键以uni或uk开头,普通索引以idx开头,一律使用小写格式,以字段的名称或缩写作为后缀。

4.【建议】多单词组成的columnname,取前几个单词首字母,加未单词组成column_name。如 sample表member_id 上的索引: idx_sample_mid。

5.【建议】单个表上的索引个数不能超过6个。

6.【建议】在建立索引时,多考虑建立联合索引,并把区分度最高的字段放在最前面。

7.【建议】在多表JOIN的SQL里,保证被驱动表的连接列上有索引,这样JOIN执行效率最高。

8.【建议】建表或加索引时,保证表里互相不存在冗余索引。比如:如果表里已经存在key(a,b),则key(a)为冗余索引,需要删除。

sql编写:

1.【强制】程序端SELECT语句必须指定具体字段名称,禁止写成*。

2.【建议】程序端insert语句指定具体字段名称,不要写成INSERT INTO t1VALUES(...)

3【建议】除静态表或小表(100行以内),DML(增删改)语句必须有WHERE条件,且使用索引查找。

4.【建议】INSERT INTO..VALUES(XX) (XX),(XX).. 这里XX的值不要超过5000个。值过多虽然上线很快,但会引起主从同步延迟。

5.【建议】SELECT语句不要使用UNION,推荐使用UNION ALL,并且UNION子句个数限制在5个以内。

6.【建议】线上环境,多表JOIN不要超过5个表。

7.【建议】减少使用ORDER BY,和业务沟通能不排序就不排序,或将排序放到程序端去做。ORDER BY、GROUP BY、DISTINCT这些语句较为耗费CPU,数据库的CPU资源是极其宝贵的。

8.【建议】包含了ORDER BY、GROUP BY、DISTINCT这些查询的语句,WHERE条件过滤出来的结果集请保持在1000行以内,否则SQL会很慢。

9.【建议】对单表的多次alter操作必须合并为一次

对于超过10ow行的大表进行alter table,必须经过DBA审核,并在业务低峰期执行,多个alter需整合在一起。因为alter table会产生表锁,期间阻塞对于该表的所有写入,对于业务可能会产生极大影响。

10.【建议】批量操作数据时,需要控制事务处理间隔时间,进行必要的sleep。

11.【建议】事务里包含SQL不超过5个。

因为过长的事务会导致锁数据较久,MySQL内部缓存、连接消耗过多等问题。

12.【建议】事务里更新语句尽量基于主键或UNIQUE KEY,如UPDATE... WHERE id=XX;否则会产生间隙锁,内部扩大锁定范围,导致系统性能下降,产生死锁。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值