时间:2021-05-24
本文实例讲述了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数据库计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
你可能想知道MySQL以下三种信息:查询结果信息:SELECT,UPDATE或DELETE语句影响的记录数。数据库和数据表的信息:包含了数据库及数据表的结构信息
Mysql中'employee'表内容如下:#__Desc__=从数据库中导出数据到excel数据表中importxlwtimportpymysqlclassM
本文实例讲述了MySQL查询语句简单操作。分享给大家供大家参考,具体如下:查询创建数据库、数据表--创建数据库createdatabasepython_test
在MySQL中,使用auto_increment类型的id字段作为表的主键,并用它作为其他表的外键,形成“主从表结构”,这是数据库设计中常见的用法。但是在具体生
在MySQL中,使用auto_increment类型的id字段作为表的主键,并用它作为其他表的外键,形成“主从表结构”,这是数据库设计中常见的用法。但是在具体生