PostgresSql 多表关联删除语句的操作
操作 删除 语句 关联 多表
2023-06-13 09:19:44 时间
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 但是缺省值并不能满足外键,那么动作就会失败
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 PostgresSql 多表关联删除语句的操作
相关文章
- 美团二面:MySQL记录锁+间隙锁可以防止删除操作而导致的幻读吗?
- 【说站】python中Git分支操作
- 将数据中心代理和Oxylabs住宅代理与MultiLogin集成的操作保姆级流程
- MySql基础-笔记4 -数据表创建、删除和数据插入、查询等操作
- 【Android 逆向】Android 逆向通用工具开发 ( 静态库项目中的网络操作核心类 CNetwork 分析 )
- 【错误记录】解压 Linux 内核报错 ( Can not create symbolic link : 客户端没有所需的特权 | Windows 中配置 7z 命令行执行解压操作 )
- 关闭Linux防火墙:一步一步简单操作.(关闭linux的防火墙)
- Launch和Shut Off操作详解 – 每天5分钟玩转 OpenStack(30)
- 轻松上手Linux系统操作,提高效率(linux怎么操作系统)
- Oracle操作:删除分区索引的步骤(oracle删除分区索引)
- 使用Linux操作水晶报表(水晶报表linux)
- MySQL语句自动生成:让你的数据库操作更高效!(mysql语句生成)
- 删除MSSQL日志:简单步骤实现提高效率(删除mssql操作日志)
- MySQL使用插入符号进行快速记录操作(mysql插入符号)
- SQL Server能否完成删除操作?(sqlserver能删吗)
- MySQL中的T表操作详解(mysql中t)
- 据用MySQL删除记录数据一步一步操作指南(c mysql删除记录数)
- 如何使用C语言操作Oracle数据库删除表(c oracle删除库表)
- Oracle数据库中修改与删除操作的实施(oracle修改删除语句)
- 删除无悔Oracle数据库中的删除操作(oracle中删除操作)
- Oracle中操作删除列的ALTER语句(oracle中删除列语句)
- Oracle一对多更新操作指南(oracle 一对多更新)
- ASP中DateDiff函数详解主要实现两日期加减操作
- PHP删除文件与文件夹操作unlink()与rmdir()这两个函数的使用
- 创建二叉树二叉树如何删除节点操作教程
- 复选框全选与全不选操作实现思路
- GridView自定义删除操作的具体方法
- mysql删除操作(delete+TRUNCATE)
- 轻松创建nodejs服务器(7):阻塞操作的实现
- js用Date对象的setDate()函数对日期进行加减操作