外键

如何解决外键

我对数据库中的外键列使用空值与默认值有疑问。在设计数据库时,我发现有关空值和默认值的许多相反意见,但并非完全针对外键(主要优点和缺点)。 目前,我正在设计一个新的数据库,该数据库将为不同的Web应用程序和具有不同数据访问方法(ORM,存储过程)的其他系统存储大量数据,我想在最低级别上实现通用规则(数据库) 。 (因此,以后不必在应用程序中担心此规则)。 举个例子,假设我有一个用户
User
表,他的国籍为
NationalityID
,带有外键列,这是表
Country
的主键
CountryID
。 现在我有两个/三个选项: 答:我允许
NationalityID
列(以及数据库中所有其他类似的外键列)为空,并且始终遵循检查空无处(在应用程序中应用规则)的通用方法 要么 B:我为每个外键都指定一个默认值,比如说“ -1”,并在每个关系表中以“ -1”作为键,所有其他数据都作为“否”。数据\”(对于本示例,在“ 3”表中,我将“ CountryID”列设置为“ -1”,对于“ 6”,我将其设置为“无数据”)。因此,每次我想知道用户的国籍时,我总是会得到没有附加代码规则的结果(无需我检查它是否为null)。 要么 C:我可以禁止外键使用null值。但这确实是我要避免的事情。 (如果没有其他数据(用户国籍),我需要选择至少存储基本数据(用户名)) 那么B是好的方法吗?我在这里想念什么?通过这种方法,我会失去更多的收益吗?我可能会遇到哪些问题(除了要小心,始终在关系表中使用ID值为“ -1”表示“没有数据”的其他列)? 您对外键默认值的好/坏经历是什么? 谢谢     

解决方法

如果将其标准化,将不会有问题。 不要将国籍放在“ 7”表中,而是创建“ 8”表,将用户链接到另一个表中的“ 9”。 如果他们在该查找表中有一个条目,那就太好了。如果不是,则无需存储
NULL
或默认值。 您需要强制执行FK关系,并允许
NULL
相反。您也不想只填充一个字段就构成不正确的信息,这否定了首先需要该字段的观点。 使用查找表,您可以完全绕开它。 这也将使您改变主意,并在将来选择一种选择。 如果使用视图,则可以选择将丢失的数据视为“ 10”或默认值,而无需更改基础数据。     ,就个人而言,我认为即使数据库中的非输入项的键值为-1,您仍将进行检查以查看是否要为每个人显示“无数据”领域。 我会坚持使用NULL。 NULL意味着没有数据,在这里就是这种情况。     ,B是一个可怕的方法。记住处理空值比必须弄清楚您使用了哪个幻数要容易得多,然后您仍然必须处理它们。使用数字1。但是我最喜欢JNK的想法。     ,我建议使用选项D。如果不是所有用户都具有定义的国籍,则该信息不属于用户表。创建一个名为UserNationality的表,该表键入UserId。     ,我喜欢您的B解决方案。也许可以将这些值映射到其他实体,因此您拥有Country和NullCountry来扩展Country并被映射到id = -1的行,并且在其方法中具有特殊的代码以使其易于处理特殊情况。 一个问题可能是,在该外键上进行外部联接将变得更加困难。 编辑:不,外部联接应该没有问题,因为没有必要进行外部联接。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res