返回顶部
首页 > 资讯 > 数据库 >必看的数据库使用规范
  • 277
分享到

必看的数据库使用规范

2024-04-02 19:04:59 277人浏览 泡泡鱼
摘要

导读: 关于Mysql数据库规范,相信大家多少看过一些文档。本篇文章给大家详细分类总结了数据库相关规范,从库表命名设计规范讲起,到索引设计规范,后面又给出sql编写方面的建议。相信这些规范适用于大多数公司,

导读: 
关于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会很慢。
    必看的数据库使用规范
您可能感兴趣的文档:

--结束END--

本文标题: 必看的数据库使用规范

本文链接: https://lsjlt.com/news/36482.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 必看的数据库使用规范
    导读: 关于MySQL数据库规范,相信大家多少看过一些文档。本篇文章给大家详细分类总结了数据库相关规范,从库表命名设计规范讲起,到索引设计规范,后面又给出SQL编写方面的建议。相信这些规范适用于大多数公司,...
    99+
    2024-04-02
  • 必看的数据库规范
    关于库: 【强制】库的名称必...
    99+
    2024-04-02
  • MySQL数据库的使用规范
    这篇文章给大家分享的是有关MySQL数据库的使用规范的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。一个平台或系统随着时间的推移和用户量的增多,数据库操作往往会变慢;而在Java应...
    99+
    2024-04-02
  • 数据库规范化的必要性是什么
    这篇文章给大家分享的是有关数据库规范化的必要性是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。规范化过程主要为克服数据库逻辑结构中的插入异常、删除异常以及冗余度大的缺陷。数据...
    99+
    2024-04-02
  • 数据库设计的范式规范
    关系型数据库的设计遵循六大范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)。 第一范式 1NF 1NF,即数...
    99+
    2024-04-02
  • 数据库设计规范
    (如果两个关联的列的数据类型不一样,在关联的时候会进行隐式转换,造成列上索引失效,查询效率大幅降低)没特殊需求的情况下,统一使用innodb统一字符集可以避免由于字符集转换产生的乱码,数据库和表字符集统一使...
    99+
    2024-04-02
  • 数据库规范化设计
    操作异常 修改异常、插入异常、删除异常 数据依赖 数据间的联系 函数依赖FD 属性捡的联系,最基本的数据依赖 若确定X,则可以唯一的确定Y,则称Y依赖于X记X->Y 若X->Y,且Y是X的子集则称为平凡的函数依赖:平凡的FD 若X...
    99+
    2018-08-29
    数据库规范化设计
  • 阿里:MySQL数据库规范
    阿里:MySQL数据库规范 简介:基于阿里数据库设计规范扩展而来   设计规范 1.【推荐】字段允许适当冗余,以提高查询性能,但必须考虑数据一致。冗余字段应遵循: 不是频繁修改的字段。 不是 varchar 超长字段,更不能...
    99+
    2021-01-23
    阿里:MySQL数据库规范
  • mysql数据库设计规范
    一、数据库设计规范1.使用innodb引擎2.数据库和表的字符集统一使用utf83.所有表和字段添加注释4.单表数据量控制...
    99+
    2019-12-06
    mysql数据库设计规范
  • mysql数据库的规范有哪些
    今天就跟大家聊聊有关mysql数据库的规范有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。基础规范【建议】使用In...
    99+
    2024-04-02
  • 数据库规范化的重要性
    数据库规范化的重要性主要体现在以下几个方面:1. 数据冗余减少:规范化能够将数据分解为更小的表,避免数据的冗余存储。冗余数据不仅浪费...
    99+
    2023-10-12
    数据库
  • MySQL数据库表设计规范
    一、数据库设计 1、一般都使用 INNODB 存储引擎,除非读写比率...
    99+
    2014-11-16
    MySQL数据库表设计规范
  • 数据库操作行为规范
    (建立一个和原表相同的新表,并做表结构修改,然后将原表中的数据复制到新表中,并在原表上增加触发器,把表新增的数据也复制到新表中,在行的所有数据完成后,在原表上增加个时间很短的时间锁,把新表命名成原表,再删除...
    99+
    2024-04-02
  • MySQL数据库规范有哪些
    MySQL数据库规范有哪些,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、数据库命令规范 所有数据库对象名称必须使用小写字母并...
    99+
    2024-04-02
  • MySQL数据库有哪些规范
    今天就跟大家聊聊有关MySQL数据库有哪些规范,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。基础规范(1) 必须使用InnoDB存储引擎说明:支持事...
    99+
    2024-04-02
  • 数据库设计规范(详细)
    数据库设计规范是指在设计数据库时需要遵守的一系列规则和准则,以确保数据库结构的合理性、一致性和可维护性。下面是一些常见的数据库设计规...
    99+
    2023-09-13
    数据库
  • 数据库安全规范有哪些
    今天就跟大家聊聊有关数据库安全规范有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、     ...
    99+
    2024-04-02
  • 数据库命名规范有哪些
    本篇文章给大家分享的是有关数据库命名规范有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。数据库命名规范  采用26个英文字母(区分大小写)...
    99+
    2024-04-02
  • 数据库设计规范有哪些
    1. 数据库表命名规范:表名应该具有描述性,表名应该使用小写字母,单词之间使用下划线连接。2. 字段命名规范:字段名应该使用小写字母...
    99+
    2023-06-10
    数据库设计规范 数据库
  • java连接数据库(jdbc)的标准规范
    java连接数据库的标准规范 JDBC全称:java database connectivity ,是sun公司提供的Java连接数据库的标准规范。 localhost和127.0.0.1 都是表示当前电脑 1、oracle Oracl...
    99+
    2019-05-09
    java连接数据库(jdbc)的标准规范
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作