有关任何应用程序的第一条规则是需求会发生变化。期。因此,看起来像是今天PK的理想人选的东西可能根本不是明天的PK。
- 这是一成不变的。它永远不会改变。
- 独特性 两个记录将永远不会共享相同的ID。
就是说,在现实世界中永久地拥有具有这些特征的任何东西几乎是不可能的。我的意思是,即使某些事物今天是不变的且独特的,也并不意味着它会一直如此。
因此,请尽可能使用代理键。仅对遗留数据库使用自然键。并逃避那些建议自然键比替代(替代)更好的朋友:-)
当然,当然:您可以在数据库中使用约束来强制执行唯一性规则(就像您在示例中所做的那样),如果这是业务规则,则不可能使两个记录共享相同的值。当将来业务逻辑发生变化时,您会很高兴地看到您使用了代理密钥;-)
但是,不要为此而对stackoverflow上的随机家伙信任。阅读维基百科的这两篇文章:
http://en.wikipedia.org/wiki/Surrogate_key
http://en.wikipedia.org/wiki/Natural_key
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)