高性能可扩展MySQL数据库设计及架构优化 电商项目_1
admin
2023-05-16 18:42:34
0

一 数据库设计规范


1 命名规范 

所有数据库对象名称必须用小写字母并下划线分割

对象名称禁止使用MySQL保留关键字

命名要做到见名识义,不超过32字节

临时表必须tmp前缀 日期后缀

备份库表bak前缀 日期后缀

所有存储相同数据的列名和类型必须一致

2 数据库基本设计规范

所有表必须用innodb引擎

数据库和表字符集同意使用utf8(全存储中文的可以使用gbk 或是gbk2312)

所有表和字段都使用comment加注释

从一开始就进行数据字典的维护

尽量控制单表数据量的大小 建议500万以内

谨慎使用MySQL分区表

尽量做到冷热数据分离 减小表的宽度

禁止在表中建立预留字段

禁止在数据库中存储图片 文件等二进制数据

禁止在线上做数据库的压力测试

禁止从开发环境 测试环境连接生产环境的数据库


3索引设计规范

限制每张表索引数量,建议单张表索引不超过5个

每个innodb表必须有一个主键,不适用频繁更新的列为主键 不适用多留主键

常见索引留建议: 在select update delete语句中where从句中的列

包含在order by 、group by  distinct中的字段

多表连接的关联列

如何选择索引列的顺序:

区分度最高的列放在联合索引的最左侧(尽量选主键)

字段小的列放在联合索引的最左侧

使用最频繁的列放在联合索引的左侧

不建议使用外键约束,但是一定在表与表之间的关联键上建立索引


4 数据库字段设计规范

有限选择符合存储需要的最小的数据类型,

    比如讲字符串转化的数字类型存储

对于非负数数据采用无符号×××进行存储( unsigned int)

避免使用text blob enum类型

尽量把列定义为not null

使用大datetime 或timestamp类型存储时间

同财务相关的金额类数据 必须使用decimal类型


5 数据库sql开发规范

建议使用预编译语句进行数据库操作

避免使用双%的查询条件 如like %w%

应该对以后的扩展进行考虑

程序连接

禁止使用select *

避免使用子查询 可转化为join操作

避免使用join关联太多的表 建议不少过5个

减少同数据库的交互次数

明显不会有重复值是使用union all代替union

拆分复杂的大sql为多个小sql


6 数据库操作行为规范

超100万行的批量些操作 要分批多次进行操作

对大表使用pt-online-schema-change修改表结构

禁止为程序使用的账号赋予super权限,遵循权限最小原则,不准有drop权限


相关内容

热门资讯

大疆、影石的“师父”,撑不下去... 一则出售消息,让沉寂已久的GoPro股价突然暴涨。北京时间5月12日一早,这家美国运动相机厂商宣布,...
13岁女孩被闺蜜胁迫卖淫,父亲... 2022年6月,魏潇(化名)从得知时年13岁的女儿遭胁迫卖淫开始,便踏上了维权之路。4年来,胁迫其女...
苹果突然官宣!降到史上最低价! 近日 iPhone手机降价的消息刷屏了 网友纷纷发帖称 “零点确定降价了” “苹果坚挺了8个月终于降...
石化机械获得实用新型专利授权:... 证券之星消息,根据天眼查APP数据显示石化机械(000852)新获得一项实用新型专利授权,专利名为“...
小区2.82亩绿地“被交易”变... 近日,西安市世纪颐园小区业主向华商报大风新闻反映,小区西侧一块原本规划为公共绿地的土地,在多年前被开...
黄仁勋喝蜜雪冰城,品出了什么味... 每经评论员 朱成祥黄仁勋近期到访北京,被拍到在胡同喝豆汁、吃炸酱面、举着蜜雪冰城饮料。他表情轻松,与...
力箭系列率先实现民商火箭“百星... 来源:滚动播报 (来源:千龙网) 昨天(15日)12时33分,中科宇航力箭一号遥十三运载火箭在东风商...
B站独家直播中科院公众科学日:... 央广网北京5月16日消息(记者 殷雨婷)5月16日至17日,中国科学院第22届公众科学日在全国一百余...
飞沃科技获得实用新型专利授权:... 证券之星消息,根据天眼查APP数据显示飞沃科技(301232)新获得一项实用新型专利授权,专利名为“...
段永平的“本分”哲学,被OPP... 短短几十字的母亲节宣传文案,把OPPO推上了风口浪尖。 5月8日,手机品牌OPPO的官方微博、小红书...