主页 > 知识库 > PostgresSql 多表关联删除语句的操作

PostgresSql 多表关联删除语句的操作

热门标签:漯河外呼电话系统 合肥公司外呼系统运营商 打电话智能电销机器人授权 重庆自动外呼系统定制 美容工作室地图标注 办公外呼电话系统 外呼调研系统 地图标注和图片名称的区别 海丰有多少商家没有地图标注

最近用PostgresSql数据库进行多表关联删除的操作,在写sql语句的时候遇到了问题:

DELETE s.* FROM student s,classroom c WHERE s.cid = c.id AND s.sid = 1
DELETE FROM student s,classroom c WHERE s.cid = c.id AND s.sid = 1

上面两种写法操作后提示报错,下面是PostgresSql数据库对多表关联操作的正确用法,多张表之间用USING连接:

DELETE FROM student s USING classroom c WHERE s.cid = c.id AND s.sid = 1

补充:PostgresSQL中的限制和级联删除

删除和更新时对应的操作是一样的

1 Restrict 禁止删除被引用的行 (不能将约束检查推迟到事物的晚些时候)

2 No Action 如果存在任何引用行,则抛出错误,如果不声明任何行为则No Action就是缺省行为 (允许约束检查推迟到事物的晚些时候)

3 Cascade 在删除一个被引用的行时,引用他的行被自动删除

4 Set Null (外键上才有) 删除被引用行时,引用他的字段设置为NULL

5 Set Default (外键上才有) 删除被引用行时,引用他的字段被设置为缺省值

注意:一个动作声明为Set Default 但是缺省值并不能满足外键,那么动作就会失败

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:
  • SpringBoot连接使用PostgreSql数据库的方法
  • PostgreSQL 主备数据宕机恢复测试方案
  • PostgreSQL使用MySQL外表的步骤详解(mysql_fdw)
  • PostgreSQL LIST、RANGE 表分区的实现方案
  • 浅谈PostgreSQL的客户端认证pg_hba.conf
  • 基于PostgreSQL pg_hba.conf 配置参数的使用说明

标签:来宾 锦州 株洲 蚌埠 晋城 乌海 珠海 衡阳

巨人网络通讯声明:本文标题《PostgresSql 多表关联删除语句的操作》,本文关键词  PostgresSql,多表,关联,删除,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《PostgresSql 多表关联删除语句的操作》相关的同类信息!
  • 本页收集关于PostgresSql 多表关联删除语句的操作的相关信息资讯供网民参考!
  • 推荐文章