博客
关于我
菜鸟的mysql规范
阅读量:753 次
发布时间:2019-03-22

本文共 1023 字,大约阅读时间需要 3 分钟。

阿里巴巴Java开发手册 MySQL规范

1. 数据库规范

  • 数据库名、表名、字段名均采用小写字母和数字 组合,禁止出现大写字母和非字母符号。
  • 表名应为单数形式,符合数据库命名习惯。
  • 避免使用保留字,如descrangematch等。
  • 主键索引命名为pk_,唯一索引为uk_,普通索引为idx_
  • 使用DECIMAL类型存储小数,避免FLOATDOUBLE
  • 非负数字段必须使用unsigned类型。
  • 字符类型优先使用char,长度一致;varchar不 exceed 5000 characters,超过部分单独处理为text类型。
  • 表必备字段:id(主键),gmt_creategmt_modified
  • 表命名建议使用“业务名称_表的作用”的格式。
  • 库名与应用名称一致。
  • 2. 索引规范

  • 业务上具有唯一特性的字段需建唯一索引,或采用字段组合。
  • 优先使用覆盖索引,避免全表扫描。
  • 索引字段长度根据区分度确定。
  • 避免在varchar字段上建全长度索引。
  • 加索引前注意字段类型一致,避免隐式转换失效索引。
  • 避免右模糊和全模糊,适用分页性能优化。
  • 建组合索引时,区分度高的字段优先放前面。
  • 适度使用覆盖索引和延迟关联查询优化分页性能。
  • 3. SQL语句规范

  • 不使用COUNT(*)统计,采用COUNT(table_name)
  • 避免SUM空值引发业务逻辑错误。
  • 使用ISNULL判断空值。
  • 分页逻辑前检查COUNT是否为0。
  • 不使用触发和存储过程,加大可维护性。
  • 避免IN操作,必要时评估字段数量。
  • 数据订正前执行SELECT确认记录。
  • 不建议使用TRUNCATE TABLE,推荐DELETE操作。
  • 事务使用场景需谨慎评估,避免影响性能。
  • 避免过度使用函数如COMPARE_VALUE
  • 4. ORM映射规范

  • 不使用SELECT *,明确列出字段。
  • POJO布尔属性不使用is,数据库字段需加is_前缀。
  • 不使用#${}(hash),采用#{}占位符。
  • 避免queryForList重复.getPropertyFromList。
  • HashMap和Hashtable都不用于查询结果集。
  • 更新操作需同时更新gmt_modified字段。
  • 避免大范围更新接口,参数过滤设置合理。
  • 使用@Transactional事务需谨慎,结合业务场景评估。
  • 5. 总结

    以上规范基于阿里巴巴开发手册总结,本文旨在指导数据库设计和操作,提升开发效率和数据质量。

    转载地址:http://vamwk.baihongyu.com/

    你可能感兴趣的文章
    opencv面向对象设计初探
    查看>>
    OpenCV(1)读写图像
    查看>>
    OpenCV:不规则形状区域中每种颜色的像素数?
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    OpenDaylight融合OpenStack架构分析
    查看>>
    OpenERP ORM 对象方法列表
    查看>>
    openEuler Summit 2022 成功举行,开启全场景创新新时代
    查看>>
    openEuler 正式开放:推动计算多样化时代的到来
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
    查看>>
    OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
    查看>>
    OpenFeign 入门与实战
    查看>>
    OpenFeign源码学习
    查看>>
    OpenFeign组件声明式服务调用
    查看>>
    openfeign远程调用不起作用解决_使用Spring Boot的spring.factories进行注入---SpringCloud Alibaba_若依微服务框架改造---工作笔记007
    查看>>
    openfire开发(四)消息拦截器
    查看>>
    openfire源码解读之将cache和session对象移入redis以提升性能
    查看>>
    Openfire身份认证绕过漏洞复现+利用(CVE-2023-32315)
    查看>>
    OpenForest 开源项目安装与使用指南
    查看>>
    OpenGL glBlendFunc() 设置颜色混合 透明度叠加计算
    查看>>
    opengl 深度详解,多重采样时,如何在OpenGL纹理中解析深度值?
    查看>>