• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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数据库计有所帮助。

    您可能感兴趣的文章:
    • MySQL索引知识的一些小妙招总结
    • MySQL创建高性能索引的全步骤
    • MySQL创建索引需要了解的
    • MySQL 普通索引和唯一索引的区别详解
    • 浅谈Mysql哪些字段适合建立索引
    • Mysql删除数据以及数据表的方法实例
    • MySQL创建数据表时设定引擎MyISAM/InnoDB操作
    • 删除mysql数据表如何操作
    • 关于MYSQL 你需要知道的数据类型和操作数据表
    • MySQL创建数据表并建立主外键关系详解
    • MySQL数据表合并去重的简单实现方法
    • MySQL 索引和数据表该如何维护
    上一篇:Mysql数据库高级用法之视图、事务、索引、自连接、用户管理实例分析
    下一篇:Linux远程部署MySQL数据库详细步骤
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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