MySQL的各种键都废了吗?
发布日期:2021-06-30 12:27:21 浏览次数:2 分类:技术文章

本文共 1074 字,大约阅读时间需要 3 分钟。

        

  点击上方“JavaEdge”,关注公众号

设为“星标”,好文章不错过!

主键(primary key)

一列 (或一组列),其值能够唯一区分表中的每个行。唯一标识表中每行的这个列(或这组列)称为主键。主键用来表示一个特定的行。没有主键,更新或删除表中特定行很困难,因为没有安全方法保证只涉及相关的行而不误伤其他行!

一个顾客表可以使用顾客编号列,而订单表可以使用订单ID,雇员表可以使用雇员ID或雇员社会保险号。

应该总是定义主键 虽然并非总需主键,但大多数数据库设计人员都应保证他们创建的每个表具有一个主键,以便以后的数据操纵和管理。

表中的任何列都可以作为主键,只要它满足以下主键值规则条件:

  1. 任两行不具相同的主键值

  2. 每行都必须具有一个主键值(主键列不允许NULL)

这里的规则是MySQL本身强制实施的。

除MySQL强制实施的规则外,还应该坚持的最佳实践:

  1. 不更新主键列中的值

  2. 不重用主键列的值

  3. 不在主键列中使用可能会更改的值

    例如,如果使用一个名字作为主键以标识某个供应商,当该供应商合并和更改其
    名字时,必须更改这个主键)

联合主键

好处

可以直观的看到某个重复字段的记录条数

主键A跟主键B组成联合主键

主键A跟主键B的数据可以完全相同,联合就在于主键A跟主键B形成的联合主键是唯一的。
联合主键体现在多个表上,复合主键体现在一个表中的多个字段。

复合主键

主键通常定义在表的一列上,但这并不是必需的,也可使用多个列作为主键。此时上述的条件必须应用到构成主键的所有列,所有列值的组合必须是唯一的(多列中的单个列的值可以不唯一)。

表的主键含有一个以上的字段组成,不使用无业务含义的自增id作为主键

将多个字段设置为主键,形成复合主键,这多个字段联合标识唯一性,其中,某几个主键字段值出现重复是没有问题的,只要不是有多条记录的所有主键值完全一样,就不算重复

超键

在关系中能唯一标识元组的属性集称为关系模式的超键。一个属性可以为作为一个超键,多个属性组合在一起也可以作为一个超键。超键包含候选键和主键。

候选键

是最小超键,即没有冗余元素的超键。

外键

在一个表中存在的另一个表的主键称此表的外键

主键的选择

  • 代理主键(推荐使用)

    与业务无关的,无意义的数字序列。

  • 不与业务耦合,因此更容易维护

  • 通用的键策略能够减少要编写的源码数量,减少系统的总体拥有成本

  • 自然主键

    事物属性中的自然唯一标识

往期推荐

目前交流群已有 800+人,旨在促进技术交流,可关注公众号添加笔者微信邀请进群

喜欢文章,点个“在看、点赞、分享”素质三连支持一下~

转载地址:https://javaedge.blog.csdn.net/article/details/108701461 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:高并发系统设计之道(一)- 方法论
下一篇:彻底讲清Spring Bean

发表评论

最新留言

表示我来过!
[***.240.166.169]2024年04月06日 02时55分30秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章