外键引用可以在PostgreSQL中包含NULL值吗?

发布时间:2020-07-19 发布网站:脚本之家
脚本之家收集整理的这篇文章主要介绍了外键引用可以在PostgreSQL中包含NULL值吗?脚本之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
举个例子
create table indexing_table
(
  id SERIAL PRIMARY KEY,created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),);

下表之间有区别吗?

表格1:

create table referencing_table
(
  indexing_table_id INTEGER references indexing_table
);

表2:

create table referencing_table
(
  indexing_table_id INTEGER references indexing_table NOT NULL
);

或者,在表1的情况下,没有NOT NULL约束,我们是否允许插入包含NULL值的记录?

对于表1,此INSERT语句将成功.如果你运行100次,它将成功100次.
insert into referencing_table values (null);

表2中的相同INSERT语句将失败.

ERROR:  null value in column "indexing_table_id" violates not-null constraint
DETAIL:  Failing row contains (null).

总结

以上是脚本之家为你收集整理的外键引用可以在PostgreSQL中包含NULL值吗?全部内容,希望文章能够帮你解决外键引用可以在PostgreSQL中包含NULL值吗?所遇到的程序开发问题。

如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢交流学习经验,点击链接加入脚本之家官方QQ群:1065694478
脚本之家官方公众号

微信公众号搜索 “ 程序精选 ” ,选择关注!

微信公众号搜索 “ 程序精选 ”
精选程序员所需精品干货内容!