如何在Mysql数据库中数据表使用外键与三范式
发布时间:2022-02-15 14:24:44 所属栏目:MySql教程 来源:互联网
导读:这篇文章将为大家详细讲解有关如何在Mysql数据库中数据表使用外键与三范式,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 数据表优化 将商品信息表进行优化 1.创建商品种类表: create table if not ex
这篇文章将为大家详细讲解有关如何在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); 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; 外键 1.外键的使用: 添加外键约束,插入数据线判断cate_id是否存在于goods_cates中的id,不存在,则插入数据失败 alter table 表名1 add foreign key (字段名1) references 表名2(字段名2); (设置外键后可以防止非法数据的录入) foreign key(字段名1) references 表名2(字段名2); (也可在创建表时直接设置外键,前提是要连接的表存在) 2.外键的缺点: 虽然外键可以有效防止非法数据的录入,但是会极大降低表的更新效率,所以实际开发中,一般不适用外键约束,可以再事务层面去判断数据的合法性。 3.外键的删除: 显示创建表的语句 show create table goods; 获取外键名称后删除外键: alter table goods drop foreign key goods_ibfk_1; 三范式 1.第一范式(1NF):强调列的原子性,即列不能再分成其他列。 2.第二范式(2NF):基于1NF,表必须有一个主键,非主键字段必须完全依赖与主键,而不是只依赖于主键的一部分。 3.第三范式(3NF):基于2NF,非主键列必须直接依赖于主键,不能存在传递依赖。 符合第三范式的数据库,是比较合理的数据库。 关于如何在Mysql数据库中数据表使用外键与三范式就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。 (编辑:站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |