如何在Mysql数据库中数据表使用外键与三范式

69次阅读
没有评论

共计 1240 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关如何在 Mysql 数据库中数据表使用外键与三范式,文章内容质量较高,因此丸趣 TV 小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

数据表优化

将商品信息表进行优化

如何在 Mysql 数据库中数据表使用外键与三范式

1. 创建商品种类表:

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

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

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

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

如何在 Mysql 数据库中数据表使用外键与三范式

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

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

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

alter table goods change cate_name cate_id int unsigned not null;

如何在 Mysql 数据库中数据表使用外键与三范式

外键

1. 外键的使用:

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

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

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

如何在 Mysql 数据库中数据表使用外键与三范式

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

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

2. 外键的缺点:

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

3. 外键的删除:

显示创建表的语句

show create table goods;

如何在 Mysql 数据库中数据表使用外键与三范式

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

alter table goods drop foreign key goods_ibfk_1;

三范式

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

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

关于如何在 Mysql 数据库中数据表使用外键与三范式就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1240字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)