Oracle与PostgreSQL子查询有什么不同
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,本篇内容主要讲解"Oracle与PostgreSQL子查询有什么不同",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Oracle与PostgreSQL子查询
千家信息网最后更新 2025年11月07日Oracle与PostgreSQL子查询有什么不同
本篇内容主要讲解"Oracle与PostgreSQL子查询有什么不同",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Oracle与PostgreSQL子查询有什么不同"吧!
准确的表达应该是在子查询的having条件中出现agg函数且依赖父查询的相关字段时,Oracle支持而PG不支持。
Oracle
创建表,插入数据,执行查询,OK!
TEST-orcl@DESKTOP-V430TU3>drop table tbl1;Table dropped.TEST-orcl@DESKTOP-V430TU3>drop table tbl2;Table dropped.TEST-orcl@DESKTOP-V430TU3>drop table tbl3;Table dropped.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>create table tbl1 (id int,c1 int,c2 int,c3 int);Table created.TEST-orcl@DESKTOP-V430TU3>create table tbl2 (id int,c1 int,c2 int,c3 int);Table created.TEST-orcl@DESKTOP-V430TU3>create table tbl3 (id int,c1 int,c2 int,c3 int);Table created.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>insert into tbl1 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl1 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl1 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl1 values(2,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl1 values(2,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl1 values(3,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>insert into tbl2 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl2 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl2 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl2 values(2,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl2 values(2,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl2 values(3,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>truncate table tbl3;Table truncated.TEST-orcl@DESKTOP-V430TU3>insert into tbl3 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>insert into tbl3 values(1,1,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>commit;Commit complete.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>truncate table tbl3;Table truncated.TEST-orcl@DESKTOP-V430TU3>insert into tbl3 values(1,2,1,1);1 row created.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>select a.id,sum(a.c1) as sum_c1,sum(a.c2) as sum_c2 2 from tbl1 a,tbl2 b 3 where a.id = b.id 4 and exists (select 1 from tbl3 c where c.id = a.id group by c.id having sum(c.c1) > sum(a.c1)) 5 group by a.id; ID SUM_C1 SUM_C2---------- ---------- ---------- 1 9 9TEST-orcl@DESKTOP-V430TU3
不过,就算Oracle支持这样的写法,也不建议这样来写,原因是SQL语义理解起来并不友好,难以理解。
PG
创建表,插入数据,执行查询,出错。
[pg12@localhost ~]$ psqlExpanded display is used automatically.psql (12.1)Type "help" for help.[local:/data/run/pg12]:5120 pg12@testdb=# drop table tbl1;s(1,1,1,1);insert into tbl1 values(1,1,1,1);insert into tbl2 select * from tbl1;insert into tbl2 select * from tbl1;insert into tbl3 select * from tbl1;commit;ERROR: table "tbl1" does not exist[local:/data/run/pg12]:5120 pg12@testdb=# drop table tbl2;ERROR: table "tbl2" does not exist[local:/data/run/pg12]:5120 pg12@testdb=# drop table tbl3;ERROR: table "tbl3" does not exist[local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# create table tbl1 (id int,c1 int,c2 int,c3 int);CREATE TABLE[local:/data/run/pg12]:5120 pg12@testdb=# create table tbl2 (id int,c1 int,c2 int,c3 int);CREATE TABLE[local:/data/run/pg12]:5120 pg12@testdb=# create table tbl3 (id int,c1 int,c2 int,c3 int);CREATE TABLE[local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# insert into tbl1 values(1,1,1,1);INSERT 0 1[local:/data/run/pg12]:5120 pg12@testdb=# insert into tbl1 values(1,1,1,1);INSERT 0 1[local:/data/run/pg12]:5120 pg12@testdb=# insert into tbl1 values(1,1,1,1);INSERT 0 1[local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# insert into tbl2 select * from tbl1;INSERT 0 3[local:/data/run/pg12]:5120 pg12@testdb=# insert into tbl2 select * from tbl1;INSERT 0 3[local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# insert into tbl3 select * from tbl1;INSERT 0 3[local:/data/run/pg12]:5120 pg12@testdb=# [local:/data/run/pg12]:5120 pg12@testdb=# commit;WARNING: there is no transaction in progressCOMMIT[local:/data/run/pg12]:5120 pg12@testdb=# select a.id,sum(a.c1) as sum_c1,sum(a.c2) as sum_c2pg12@testdb-# from tbl1 a,tbl2 bpg12@testdb-# where a.id = b.idpg12@testdb-# and exists (select 1 from tbl3 c where c.id = a.id group by c.id having sum(c.c1) = sum(a.c1))pg12@testdb-# group by a.id;ERROR: aggregate functions are not allowed in WHERELINE 4: ...ere c.id = a.id group by c.id having sum(c.c1) = sum(a.c1)) ^[local:/data/run/pg12]:5120 pg12@testdb=#
出现的错误是"aggregate functions are not allowed in WHERE",但条件明明在having怎么报WHERE中出现agg函数呢?原因是PG认为条件sum(c.c1) = sum(a.c1)中的a.c1出现在父查询中,该条件认为是WHERE中的条件。
到此,相信大家对"Oracle与PostgreSQL子查询有什么不同"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
查询
条件
不同
支持
内容
函数
原因
数据
学习
实用
更深
兴趣
写法
字段
实用性
实际
建议
操作简单
方法
是在
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
光音网络技术
搜小说软件开发
双活数据中心数据库同步技术
用户信息采集网络安全
怎样做管理软件开发工程师
网易服务器能买吗
华为汽车软件开发合作企业
一个服务器电源能带两个主板吗
网络安全伴我行远程办公有风险
数据库码的英文
消逝的光芒2连不上服务器
验证token是查数据库吗
定制手机软件开发公司
2022年网络安全大事件
网络安全法专题研讨材料免费复制
互联网科技公司算企事业单位吗
数据库 表名命名规范
ipv6根服务器最新消息
计算机应用软件开发的原则
软件开发工程学
建设银行的网络安全员
语音系统与数据库的区别
初级中学网络安全亮点
软件开发流程cmmi
反诈中心app未连接到服务器
西藏网络安全宣传视频
数据库服务器如何关闭
杨浦区什么是网络技术互惠互利
泰坦陨落2社区服务器
数据库差插件