- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的问题是关于自然键和 auto_increment 整数作为主键。
例如,我有表 A
和 B
和 A_B_relation
. A 和 B 可能是某个对象,而 A_B_realtion
记录A和B的多对多关系。
A 和 B 都有自己的全局唯一 ID,例如 UUID。 UUID 可供用户使用,这意味着用户可以通过 UUID 查询 A 或 B。
有两种方法可以设计表的主键。
A_B_relation
将整数引用为 FK。 A_B_relation
将 UUID 引用为 FK。 First, query A's integer primary key by UUID from `A`.
And then, query all the B's integer primary key from `A_B_relation`.
At last, query all the B's info from `B`.
Query all the B's UUID from the `A_B_relation` by A's UUID.
Query all the B's info from `B`.
最佳答案
根据我的观点,使用自增键的自然键的方便性取决于您提供的程序解决方案。这两种方法各有利弊。所以最好的解决方案是正确理解这两种键类型,分析您尝试提供的业务解决方案类型并选择合适的主键类型。
自然键 是一列或一组列,我们可用于唯一标识表中的记录。这些列包含与表的其余列有关系的真实数据。
自动递增 key ,也称为 代理键 是单个表列,其中包含唯一的数值,可用于唯一标识表中的单行数据。这些值是在运行时将记录插入到表中时生成的,并且与行的其余数据没有关系。
使用自然键的主要优点是它有它自己的意义并且需要更少的与其他表的连接,就像我们使用代理键一样,我们需要连接到外键表才能获得我们使用自然键得到的结果。
但是假设我们无法从单个表中获取所需的所有数据,而必须与另一个表连接才能获取所需的所有数据。然后使用代理键代替自然键很方便,因为大多数时候自然键是字符串并且比代理键的大小更大,并且使用更大的值连接表将花费更多时间。
一个自然键有它自己的意义。因此,在搜索记录时,使用自然键比使用代理键更有利。但是随着时间的推移,我们的程序逻辑发生了变化,我们必须改变自然键值。这将是困难的,并且会导致对所有外键关系的级联效应。我们可以使用代理键来解决这个问题。由于代理键与行的其余值没有关系,因此逻辑的更改不会对代理键产生影响。
同样,正如我所看到的,完全基于您提供的解决方案使用代理键或自然键的方便和不便。
关于primary-key - 自然键 vs auto_increment 键作为主键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33053331/
我有一套使用两种语言的文档:英语和德语。关于这些文档没有可用的元信息,程序只能查看其内容。基于此,程序必须决定用哪种语言编写文档。 是否有可以在几个小时内实现的针对该问题的“标准”算法?或者,一个免费
背景 我有一个日志系统,可以将记录输出到 std::ostream .每条记录都用一个计数器进行注释,该计数器随着每个输出而增加 1,如下所示: ===== Batch # 5 ===== T
用户可能希望根据需要分隔数字。 从字符串中提取所有(自然)数字的最有效(或简单的标准函数)是什么? 最佳答案 您可以使用正则表达式。我从 Sun's regex matcher tutorial 修改
我认为如果表有代理键而没有(自然)替代键是没有意义的(请记住,代理键的属性之一是它在数据库之外没有意义环境)。 例如假设我有下表: 假设 employee_id 是代理主键,表中没有(自然)备用键。
我想将屏幕方向锁定为其默认方向。我在实现这一点时遇到问题。最初我将屏幕锁定为 list 中的肖像。它适用于纵向默认设备。但是许多平板电脑默认为横向,因此在这些设备中锁定纵向是不合适的,我想检测此默认方
我已将笔记本电脑上的触摸板滚动设置为倒置(自然)。它适用于任何地方(pdf、浏览器等),但在 vscode 中,它坚持正常滚动。通过 vscode 的设置文件没有显示适当的条目。 系统:Ubuntu
在我发现的许多在上限集合上使用可尾游标的示例中,代码包括: hint( { $natural: 1 } ) (例如 here ),包括官方文档 ( here ),以“确保我们不使用任何索引”,并且结果
@override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: T
一些上下文:Node.js、Bot、natural module . 我想构建一个机器人,并且我正在使用自然模块来解析用户输入并对其进行总体分类。 var classifier = new natur
我是一名优秀的程序员,十分优秀!