我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL数据库的设计规范与原则

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL数据库的设计规范与原则

今天小编就为大家带来一篇有关MySQL数据库的设计规范与原则的文章。小编觉得总结全面到位,为此分享给大家做个参考。一起跟随小编过来看看吧。

1、数据库命名规范

采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线'_'组成;

命名简洁明确(长度不能超过30个字符);

例如:user, stat, log, 也可以wifi_user, wifi_stat, wifi_log给数据库加个前缀;

除非是备份数据库可以加0-9的自然数:user_db_20151210;

2、数据库表名命名规范

采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线'_'组成;

命名简洁明确,多个单词用下划线'_'分隔;

例如:user_login, user_profile, user_detail, user_role, user_role_relation,

user_role_right, user_role_right_relation

表前缀'user_'可以有效的把相同关系的表显示在一起;

3、数据库表字段名命名规范

采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线'_'组成;

命名简洁明确,多个单词用下划线'_'分隔;

例如:user_login表字段 user_id, user_name, pass_word, eamil, tickit, status, mobile, add_time;

每个表中必须有自增主键,add_time(默认系统时间)

表与表之间的相关联字段名称要求尽可能的相同;

4、数据库表字段类型规范

用尽量少的存储空间来存数一个字段的数据;

例如:能使用int就不要使用varchar、char,能用varchar(16)就不要使用varchar(256);

IP地址最好使用int类型;

固定长度的类型最好使用char,例如:邮编;

能使用tinyint就不要使用smallint,int;

最好给每个字段一个默认值,最好不能为null;

5、数据库表索引规范

命名简洁明确,例如:user_login表user_name字段的索引应为user_name_index唯一索引;

为每个表创建一个主键索引;

为每个表创建合理的索引;

建立复合索引请慎重;

6、简单熟悉数据库范式

第一范式(1NF):字段值具有原子性,不能再分(所有关系型数据库系统都满足第一范式);

例如:姓名字段,其中姓和名是一个整体,如果区分姓和名那么必须设立两个独立字段;

第二范式(2NF):一个表必须有主键,即每行数据都能被唯一的区分;

备注:必须先满足第一范式;

第三范式(3NF):一个表中不能包涵其他相关表中非关键字段的信息,即数据表不能有沉余字段;

备注:必须先满足第二范式;

数据库的三范式:

①字段不可分。

②有主键,非主键字段依赖主键。

③非主键字段不能互相依赖。

MYSQL数据库设计原则

1、核心原则

不在数据库做运算;

cpu计算务必移至业务层;

控制列数量(字段少而精,字段数建议在20以内);

平衡范式与冗余(效率优先;往往牺牲范式)

拒绝3B(拒绝大sql语句:big sql、拒绝大事物:big transaction、拒绝大批量:big batch);

2、字段类原则

用好数值类型(用合适的字段类型节约空间);

字符转化为数字(能转化的最好转化,同样节约空间、提高查询性能);

避免使用NULL字段(NULL字段很难查询优化、NULL字段的索引需要额外空间、NULL字段的复合索引无效);

少用text类型(尽量使用varchar代替text字段);

3、索引类原则

合理使用索引(改善查询,减慢更新,索引一定不是越多越好);

字符字段必须建前缀索引;

不在索引做列运算;

innodb主键推荐使用自增列(主键建立聚簇索引,主键不应该被修改,字符串不应该做主键)(理解Innodb的索引保存结构就知道了);

不用外键(由程序保证约束);

4、sql类原则

sql语句尽可能简单(一条sql只能在一个cpu运算,大语句拆小语句,减少锁时间,一条大sql可以堵死整个库);

简单的事务;

避免使用trig/func(触发器、函数不用客户端程序取而代之);

不用select *(消耗cpu,io,内存,带宽,这种程序不具有扩展性);

OR改写为IN(or的效率是n级别);

OR改写为UNION(mysql的索引合并很弱智);

select id from t where phone = ’159′ or name = ‘john’;

=>

select id from t where phone=’159′
union
select id from t where name=’jonh’

避免负向%;

慎用count(*);

limit高效分页(limit越大,效率越低);

使用union all替代union(union有去重开销);

少用连接join;

使用group by;

请使用同类型比较;

打散批量更新;

5、性能分析工具

show profile;

mysqlsla;

mysqldumpslow;

explain;

show slow log;

show processlist;

以上就是MySQL数据库的设计规范与原则的详细内容了,看完之后是否有所收获呢?如果想了解更多相关内容,欢迎关注亿速云行业资讯!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL数据库的设计规范与原则

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

golang函数设计原则与规范

go函数设计原则包括:可读性(使用有意义的名称、简短的函数体和避免嵌套函数)、可维护性(错误处理、值传递和输入验证)和可重用性(包分组、接口定义和文档字符串)。遵循这些原则有助于编写清晰、可维护和可重用的go函数。这将极大地提高代码质量和开
golang函数设计原则与规范
2024-04-26

mysql数据库设计规范

一、数据库设计规范1.使用innodb引擎2.数据库和表的字符集统一使用utf83.所有表和字段添加注释4.单表数据量控制<500w5.谨慎使用mysql分区,跨区查询影响性能6.冷热数据分离,缓存7.禁止在数据库中存储图片,文件等大的二进制数据8.禁止在线上
mysql数据库设计规范
2019-12-06

MySQL数据库表设计规范

一、数据库设计 1、一般都使用 INNODB 存储引擎,除非读写比率<1%,才考虑使用 MYISAM 存储引擎;其 他存储引擎请在 DBA 的建议下使用。 2、Stored procedure (包括存储过程,函数,触发器)对于 MYSQL 来说还不是很成熟,
MySQL数据库表设计规范
2014-11-16

MySQL数据库设计原则

MySQL数据库设计原则主要涉及到以下几个方面:规范化:规范化是数据库设计的基本原则之一,主要是为了解决数据冗余、更新异常、插入异常和删除异常等问题。通过将数据分解成较小的、结构良好的部分,可以减少数据冗余,提高数据的一致性和完整性。MyS
MySQL数据库设计原则
2024-10-20

数据库规范化设计

操作异常修改异常、插入异常、删除异常数据依赖数据间的联系函数依赖FD属性捡的联系,最基本的数据依赖若确定X,则可以唯一的确定Y,则称Y依赖于X记X->Y若X->Y,且Y是X的子集则称为平凡的函数依赖:平凡的FD若X->Y且对于任何并且对于X的任何一 个真子集X
数据库规范化设计
2018-08-29

数据库设计规范(详细)

数据库设计规范是指在设计数据库时需要遵守的一系列规则和准则,以确保数据库结构的合理性、一致性和可维护性。下面是一些常见的数据库设计规范:1. 数据库命名规范:- 数据库名、表名、字段名应使用有意义的英文单词或词组,避免使用缩写、拼音或无意义
2023-09-13

PHP面向对象编程:设计原则与规范

oop 设计原则和规范有助于构建可维护和可扩展的 php 代码。遵循的原则包括:单一职责原则 (srp):每个类负责一项任务。开放-封闭原则 (ocp):可扩展而无需修改。里氏替换原则 (lsp):派生类无缝替换基类。依赖倒置原则 (dip
PHP面向对象编程:设计原则与规范
2024-05-11

MySQL数据库分区表设计原则

MySQL数据库分区表设计原则涉及多个方面,以下是一些关键原则:选择合适的分区键:分区键应该是经常用于查询和筛选的字段,同时要确保分区键的数据分布均匀,避免数据倾斜。根据查询频率进行分区:将经常查询的数据放在较小的分区中,减少查询范围,加
MySQL数据库分区表设计原则
2024-10-21

数据库设计规范有哪些

1. 数据库表命名规范:表名应该具有描述性,表名应该使用小写字母,单词之间使用下划线连接。2. 字段命名规范:字段名应该使用小写字母,单词之间使用下划线连接。3. 数据类型规范:选择适当的数据类型,避免使用不必要的数据类型。4. 主键规范:
2023-06-10

编程热搜

目录