当前位置: 首页 > 编程笔记 >

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

左凯定
2023-03-14
本文向大家介绍Mysql数据库中数据表的优化、外键与三范式用法实例分析,包括了Mysql数据库中数据表的优化、外键与三范式用法实例分析的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了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相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》

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

 类似资料:
  • 本文向大家介绍实例分析ORACLE数据库性能优化,包括了实例分析ORACLE数据库性能优化的使用技巧和注意事项,需要的朋友参考一下 ORACLE数据库的优化方式和MYSQL等很大的区别,今天通过一个ORACLE数据库实例从表格、数据等各个方便分析了如何进行ORACLE数据库的优化。 tsfree.sql视图 这个sql语句迅速的对每一个表空间中的空间总量与每一个表空间中可用的空间的总量进行比较 表

  • 我正在尝试在table of数据库与table of数据库之间创建外键: 用户id int(10)未签名的编号 Id int(10)无符号编号 我创建了查询 "外键约束格式错误"有人能帮助我如何实现这一点吗?

  • 我有4个实体列在下面的职位。客户端和产品已在数据库中。问题在于订单和订单产品。我创建Orders对象,然后添加客户机(已经在数据库中)和OrdersProducts的ArrayList,但出现了错误: 当我不添加客户机时,数据库中只有OrderProducts的ArrayList,但OrderProducts没有外键。怎么了?我使用Mysql服务器和hibernate。

  • 本文向大家介绍PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】,包括了PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP连接MySQL数据库的三种方式。分享给大家供大家参考,具体如下: PHP与MySQL的连接有三种API接口,分别是:PHP的MySQL扩展 、PHP的mys

  • 本文向大家介绍SqlServer 数据库 三大  范式,包括了SqlServer 数据库 三大  范式的使用技巧和注意事项,需要的朋友参考一下 1 概述 一般地,在进行数据库设计时,应遵循三大原则,也就是我们通常说的三大范式,即第一范式要求确保表中每列的原子性,也就是不可拆分;第二范式要求确保表中每列与主键相关,而不能只与主键的某部分相关(主要针对联合主键),主键列与非主键列遵循完全函数依赖关系,

  • 我对Laravel和数据库都是新手。我正在写一个学生评估的网络应用程序。我有一个现有的MySQL数据库,它已经包含了我所需要的一切;但是,我正在使用Laravel的auth user表,并尝试添加一个外键,该外键引用MySQL数据库中的教师表。我一直得到以下错误。。。 在Connection.php第664行: SQLSTATE[HY000]:一般错误:1215不能添加外键约束(SQL:改变表添加