服务器之家

服务器之家 > 正文

Mysql数据库中数据表的优化、外键与三范式用法实例分析

时间:2020-12-18 16:40     来源/作者:MYSQL教程网

本文实例讲述了Mysql数据库中数据表优化外键与三范式用法。分享给大家供大家参考,具体如下:

数据表优化

将商品信息表进行优化

Mysql数据库中数据表的优化、外键与三范式用法实例分析

1.创建商品种类表:

?
1
2
3
4
create table if not exists goods_cates(
id int unsigned primary key auto_increment,
name varchar(40) not null
);

2.将商品种类写入商品种类表中:

注意:插入另一个表的查询结果不需要加values

?
1
2
insert into goods_cates(name)
(select cate_name from goods group by cate_name);

Mysql数据库中数据表的优化、外键与三范式用法实例分析

3.将商品种类表更新到商品表中:

将商品表与种类表连接,用种类表id代替商品表种类内容

?
1
2
update (goods_cates inner join goods on goods_cates.name=goods.cate_name)
set goods.cate_name=goods_cates.id;

4.修改表结构:

将商品表商品种类名字段名cate_name重命名为cate_id

?
1
alter table goods change cate_name cate_id int unsigned not null;

Mysql数据库中数据表的优化、外键与三范式用法实例分析

外键

1.外键的使用:

添加外键约束,插入数据线判断cate_id是否存在于goods_cates中的id,不存在,则插入数据失败

?
1
alter table 表名1 add foreign key (字段名1) references 表名2(字段名2);

(设置外键后可以防止非法数据的录入)

Mysql数据库中数据表的优化、外键与三范式用法实例分析

?
1
foreign key(字段名1) references 表名2(字段名2);

(也可在创建表时直接设置外键,前提是要连接的表存在)

2.外键的缺点:

虽然外键可以有效防止非法数据的录入,但是会极大降低表的更新效率,所以实际开发中,一般不适用外键约束,可以再事务层面去判断数据的合法性。

3.外键的删除:

显示创建表的语句

?
1
show create table goods;

Mysql数据库中数据表的优化、外键与三范式用法实例分析

获取外键名称后删除外键:

?
1
alter table goods drop foreign key goods_ibfk_1;

三范式

1.第一范式(1NF):强调列的原子性,即列不能再分成其他列。
2.第二范式(2NF):基于1NF,表必须有一个主键,非主键字段必须完全依赖与主键,而不是只依赖于主键的一部分。
3.第三范式(3NF):基于2NF,非主键列必须直接依赖于主键,不能存在传递依赖。

符合第三范式的数据库,是比较合理的数据库。

希望本文所述对大家MySQL数据库计有所帮助。

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享 2020-04-07
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址 2020-08-12
最新idea2020注册码永久激活(激活到2100年)
最新idea2020注册码永久激活(激活到2100年) 2020-07-29
返回顶部