栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

具有NULL的唯一键

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

具有NULL的唯一键

唯一密钥的 基本属性是它必须是唯一的。使该键成为Nullable的一部分会破坏此属性。

有两种可能的解决方案来解决您的问题:

  • 一种方法(错误的方法)是使用一些魔术日期来表示未知数。这只是使您克服了DBMS的“问题”,但并不能从逻辑上解决问题。预期两个“约翰·史密斯”条目的生日不明的问题。这些家伙是同一个人还是独特的个人?如果您知道它们不同,那么您又回到了同样的旧问题-您的唯一密钥不是唯一的。甚至不要考虑分配一个完整的魔术日期来表示“未知”,这确实是通往地狱的道路。

  • 更好的方法是将EmployeeId属性创建为代理键。这只是您分配给 知道 唯一的个人的任意标识符。该标识符通常只是一个整数值。然后创建一个Employee表,以将EmployeeId(唯一的,不可为空的键)与您认为是依赖属性的属性相关联,在这种情况下,名称和出生日期(其中任何一个都可以为空)。在以前使用姓名/生日的任何地方使用EmployeeId代理键。这将向您的系统添加一个新表,但是以一种可靠的方式解决了未知值的问题。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/432901.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号