百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> MySQL设计标准与准则
分享文章到:

MySQL设计标准与准则

发布时间:09/01 来源:未知 浏览: 关键词:
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教程》

以上就是MySQL设计标准与原则的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有154人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板