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 但是缺省值并不能满足外键,那么动作就会失败

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

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐