Oracle与PostgreSQL子查询有什么不同
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,本篇内容主要讲解"Oracle与PostgreSQL子查询有什么不同",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Oracle与PostgreSQL子查询
千家信息网最后更新 2025年01月31日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安全错误
数据库的锁怎样保障安全
数据库查锁
游戏开发者和企业服务器
数据库寻址
亿账通互联网科技
代理文件放到服务器哪里
大话西游相聚长安服务器没了
网络安全态势感知是什么意思
锦江区租房软件开发
计算机信息网络安全管理试题
网络安全公开课怎么讲
diag数据库日志怎么看
方舟服务器管理器代码
金融超市软件开发
资阳网络技术推荐厂家
一对一网络技术服务口碑推荐
无锡常规软件开发进货价
恩施市网络安全进校园线上
中商情报网数据库家庭教育
阿里服务器建站
软件开发公司如何找客户公司
ef 数据库编码
服务器显卡好换吗
幻塔服务器开服哪个人多
软件开发的税点是谁承担
大话西游新出的服务器
软件开发不同周期使用的工具
郑州网络技术投资
网络安全者的安全义务
数据库表状态1
虚拟世界服务器被炸