• 【JAVA开发规范学习之 MySQL数据库】


    JAVA开发规范学习之 MySQL数据库(阿里巴巴开发规范)
    总结:
    1.建表规约
    【强制】主键索引名为 pk_字段名;唯一索引名为 uk_字段名;普通索引名则为 idx_字段名。说明:pk_ 即 primary key;uk_ 即 unique key;idx_ 即 index 的简称。
    【强制】小数类型为 decimal,禁止使用 float 和 double。
    说明:float 和 double 在存储的时候,存在精度损失的问题,很可能在值的比较时,得到不正确的结果。如果存储的数据范围超过 decimal 的范围,建议将数据拆成整数和小数分开存储。
    【强制】如果存储的字符串长度几乎相等,使用 char 定长字符串类型。
    【强制】varchar 是可变长字符串,不预先分配存储空间,长度不要超过 5000,如果存储长度大于此值,定义字段类型为 text,独立出来一张表,用主键来对应,避免影响其它字段索引效率。
    【推荐】字段允许适当冗余,以提高查询性能,但必须考虑数据一致。冗余字段应遵循:
    【推荐】单表行数超过 500 万行或者单表容量超过 2GB,才推荐进行分库分表
    2.索引规约
    【强制】业务上具有唯一特性的字段,即使是多个字段的组合,也必须建成唯一索引,即使在应用层做了非常完善的校验控制,只要没有唯一索引,根据墨菲定律,必然有脏数据产生。
    【强制】超过三个表禁止 join。需要 join 的字段,数据类型必须绝对一致;多表关联查询时, 保证被关联的字段需要有索引。
    【强制】在 varchar 字段上建立索引时,必须指定索引长度,没必要对全字段建立索引,根据实际文本区分度决定索引长度即可。
    【强制】页面搜索严禁左模糊或者全模糊,如果需要请走搜索引擎来解决。
    【推荐】如果有 order by 的场景,请注意利用索引的有序性。order by 最后的字段是组合索引的一部分,并且放在索引组合顺序的最后,避免出现 file_sort 的情况,影响查询性能。
    【推荐】利用覆盖索引来进行查询操作,避免回表。
    【推荐】建组合索引的时候,区分度最高的在最左边。
    【推荐】防止因字段类型不同造成的隐式转换,导致索引失效
    3.SQL 语句
    【强制】不要使用 count(列名)或 count(常量)来替代 count(),count()是 SQL92 定义的标准统计行数

  • 相关阅读:
    基于 ARM+FPGA+AD平台的多类型同步信号采集仪开发及试验验证(一)上位机设计
    异常与智能指针
    【Linux】GDB调试
    Http基础之http协议、无状态协议、状态码、http报文、跨域-cors
    【C++】C++基础知识(五)---数组
    HTML数字倒计时效果附源码
    新的ASP.NET Core 迁移指南
    计算机操作系统 第三章:处理机调度与死锁(2)
    Docker
    2.1 Elasticsearch DSL搜索-数据准备
  • 原文地址:https://blog.csdn.net/t194978/article/details/126197879