各位用户为了找寻关于Mysql数据库中数据表的优化、外键与三范式用法实例分析的资料费劲了很多周折。这里教程网为您整理了关于Mysql数据库中数据表的优化、外键与三范式用法实例分析的相关资料,仅供查阅,以下为您介绍关于Mysql数据库中数据表的优化、外键与三范式用法实例分析的详细内容
本文实例讲述了Mysql数据库中数据表的优化、外键与三范式用法。分享给大家供大家参考,具体如下:
数据表优化
将商品信息表进行优化
1.创建商品种类表:
? 1 2 3 4create
table
if
not
exists goods_cates(
id
int
unsigned
primary
key
auto_increment,
name
varchar
(40)
not
null
);
2.将商品种类写入商品种类表中:
注意:插入另一个表的查询结果不需要加values
? 1 2insert
into
goods_cates(
name
)
(
select
cate_name
from
goods
group
by
cate_name);
3.将商品种类表更新到商品表中:
将商品表与种类表连接,用种类表id代替商品表种类内容
? 1 2update
(goods_cates
inner
join
goods
on
goods_cates.
name
=goods.cate_name)
set
goods.cate_name=goods_cates.id;
4.修改表结构:
将商品表商品种类名字段名cate_name重命名为cate_id
? 1alter
table
goods change cate_name cate_id
int
unsigned
not
null
;
外键
1.外键的使用:
添加外键约束,插入数据线判断cate_id是否存在于goods_cates中的id,不存在,则插入数据失败
? 1alter
table
表名1
add
foreign
key
(字段名1)
references
表名2(字段名2);
(设置外键后可以防止非法数据的录入)
foreign
key
(字段名1)
references
表名2(字段名2);
(也可在创建表时直接设置外键,前提是要连接的表存在)
2.外键的缺点:
虽然外键可以有效防止非法数据的录入,但是会极大降低表的更新效率,所以实际开发中,一般不适用外键约束,可以再事务层面去判断数据的合法性。
3.外键的删除:
显示创建表的语句
? 1show
create
table
goods;
获取外键名称后删除外键:
? 1alter
table
goods
drop
foreign
key
goods_ibfk_1;
三范式
1.第一范式(1NF):强调列的原子性,即列不能再分成其他列。 2.第二范式(2NF):基于1NF,表必须有一个主键,非主键字段必须完全依赖与主键,而不是只依赖于主键的一部分。 3.第三范式(3NF):基于2NF,非主键列必须直接依赖于主键,不能存在传递依赖。
符合第三范式的数据库,是比较合理的数据库。
希望本文所述对大家MySQL数据库计有所帮助。