承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

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

管理员 2023-07-19 07:58:53 互联网圈 0 ℃ 0 评论 1625字 收藏

最近用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 但是缺省值其实不能满足外键,那末动作就会失败

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有毛病或未斟酌完全的地方,望不吝赐教。

文章来源:丸子建站

文章标题:PostgresSql 多表关联删除语句的操作

https://www.wanzijz.com/view/65286.html

相关文章

Related articles

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信