关于外键是什么,具体不再详述,可以自行百度。

讲一下关于外键的

On Delete和On Update的使用

最近在项目的表中看到这些,不懂顺便查了查:

ONSTRAINT "c_clusters_pkey" PRIMARY KEY ("cluster_id"),
CONSTRAINT "c_clusters_zabbix_group_id_fkey" FOREIGN KEY ("zabbix_group_id") REFERENCES "public"."groups" ("groupid") ON DELETE NO ACTION ON UPDATE NO ACTION ALTER TABLE "public"."c_clusters" OWNER TO "postgres"; CREATE UNIQUE INDEX "clusters_cluster_id_key" ON "public"."c_clusters" USING btree (cluster_id);

  其中关于

 ON DELETE NO ACTION ON UPDATE NO ACTION

On Delete和On Update都有Restrict,No Action, Cascade,Set Null属性。现在分别对他们的属性含义做个解释。

  • ON DELETE

restrict(约束):当在父表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除。

no action:意思同restrict.即如果存在从数据,不允许删除主数据。

cascade(级联):当在父表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有则也删除外键在子表(即包含外键的表)中的记录。

set null:当在父表(即外键的来源表)中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(不过这就要求该外键允许取null)

  • ON UPDATE

restrict(约束):当在父表(即外键的来源表)中更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许更新。

no action:意思同restrict.

cascade(级联):当在父表(即外键的来源表)中更新对应记录时,首先检查该记录是否有对应外键,如果有则也更新外键在子表(即包含外键的表)中的记录。

set null:当在父表(即外键的来源表)中更新对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(不过这就要求该外键允许取null)。

注:NO ACTION和RESTRICT的区别:只有在及个别的情况下会导致区别,前者是在其他约束的动作之后执行,后者具有最高的优先权执行。

最新文章

  1. 开博客这么久以来,第一篇技术文章,python与c的接口对接
  2. Intent传递对象的两种方法(Serializable,Parcelable) (转)
  3. Spring3.2.2之后不赞成使用queryForInt
  4. JavaEE基础(二十一)/IO流
  5. poj 2782 Bin Packing (贪心+二分)
  6. mybatis分页插件以及懒加载
  7. 问题:Excel在“xxx.xlsx”中发现不可读取的内容。是否恢复此工作薄的内容?【原创】
  8. 支付宝集成时的InvalidKeySpecException
  9. 手机自动化测试:appium源码分析之bootstrap十四
  10. Maven 本地仓库明明有jar包,pom文件还是报错解决办法
  11. Leetcode_28_Implement strStr
  12. javaWeb项目中的路径格式 请求url地址 客户端路径 服务端路径 url-pattern 路径 获取资源路径 地址 url
  13. Problem J. Journey with Pigs
  14. jedis单机版应用
  15. Callable和Future出现的原因
  16. MT【229】最小值函数
  17. ODPS
  18. Hadoop---集群的搭建(仅主机模式)
  19. Embedded SW uses STL or not
  20. 数据仓库专题20-案例篇:电商领域数据主题域模型设计v0.2(改进意见征集中)

热门文章

  1. SQL语句(十一)函数查询
  2. Mysql MERGE引擎简介
  3. J - FatMouse's Speed dp
  4. Hibernate的批量查询
  5. linux下usb转串口驱动分析【转】
  6. jquery实现模拟select下拉框效果
  7. Smarty 模板引擎简介
  8. 浙江省“一卡通”异地就医,C#调用省一卡通动态库
  9. mysql 索引理解
  10. 【LOJ】#2532. 「CQOI2018」社交网络