PostgresSql 多表关联删除语句的操作
程序员文章站
2022-04-01 08:05:13
最近用postgressql数据库进行多表关联删除的操作,在写sql语句的时候遇到了问题:delete s.* from student s,classroom c where s.cid = c.i...
最近用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 但是缺省值并不能满足外键,那么动作就会失败
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
上一篇: 我可以回收一笔了
推荐阅读
-
Oracle中多表关联批量插入批量更新与批量删除操作
-
PostgresSql 多表关联删除语句的操作
-
SQL语句对数据表记录进行添加,删除,修改的操作讲解
-
用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备
-
XMPP框架 微信项目开发之CoreData学习——CoreData的多表关联操作
-
用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备
-
javascript - 多表关联查询语句中在in里面放一个巨大的用户id数组导致查询时间过长如何优化?
-
MySQL多表关联数据同时删除sql语句
-
javascript - 多表关联查询语句中在in里面放一个巨大的用户id数组导致查询时间过长如何优化?
-
请问关于PHP中关联多表相关字段,并做分页处理的SQL语句写法