休眠:复合PK与代理PK中的观点

休眠:复合PK与代理PK中的观点,第1张

休眠:复合PK与代理PK中的观点

有关任何应用程序的第一条规则是需求会发生变化。期。因此,看起来像是今天PK的理想人选的东西可能根本不是明天的PK。

如果值包含以下特征,则它是PK的良好候选者

  1. 这是一成不变的。它永远不会改变。
  2. 独特性 两个记录将永远不会共享相同的ID。

就是说,在现实世界中永久地拥有具有这些特征的任何东西几乎是不可能的。我的意思是,即使某些事物今天是不变的且独特的,也并不意味着它会一直如此。

因此,请尽可能使用代理键。仅对遗留数据库使用自然键。并逃避那些建议自然键比替代(替代)更好的朋友:-)

当然,当然:您可以在数据库中使用约束来强制执行唯一性规则(就像您在示例中所做的那样),如果这是业务规则,则不可能使两个记录共享相同的值。当将来业务逻辑发生变化时,您会很高兴地看到您使用了代理密钥;-)

但是,不要为此而对stackoverflow上的随机家伙信任。阅读维基百科的这两篇文章:

http://en.wikipedia.org/wiki/Surrogate_key

http://en.wikipedia.org/wiki/Natural_key



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5442600.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-11
下一篇 2022-12-11

发表评论

登录后才能评论

评论列表(0条)

保存