Oracle数据库Bug:相关子查询多层嵌套报错:标识符无效

Oracle Bug?

一、案例描述

  • 在Mysql中常常有如下写法
  • 用相关子查询 + order by desc + limit 1来完成需求
sql 复制代码
select code,
       date,
       (select value 
         from test t1 
        where t.code = t1.code 
          and t1.date between date_sub(t.date,interval 1 year) and t.date 
        order by t1.date desc 
        limit 1) as value
  from test t

因为oracle不支持limit,所以必须改写为row_number()或者rownum,如下所示

sql 复制代码
select code,
       date,
       (select value
          from (
		       select value,row_number()over(order by t1.date desc) as rn
		         from test t1 
		        where t.code = t1.code 
		          and t1.date between date_sub(t.date,interval 1 year) and t.date
		          ) 
		  where rn <= 1
         ) as value
  from test t

把这条Sql拿到Oracle去执行,是报错的,报date标识符无效,这明显不大合理,在我的印象中,oracle是支持这种写法的,而且一般Mysql支持的特性Oracle也支持,后面发现是oracle版本的问题

我把这条Sql语句拿到Oracle 19c执行是没有问题的,而报错的oracle版本是11.2.0.3.0

二、解决方案

<一>、升级版本

  • 19c是支持的,可以试下12c或其它版本

<二>、改写语句

  • keep函数:取同一个分组下以某个字段排序后,对指定字段取最小或最大的那个值

语法:

min | max (column1) keep (dense_rank first | last order by column2) over (partition by column3)

  • 最前是聚合函数,如min、max、sum、avg ...
  • column1是要计算的列
  • dense_rank first | last是keep的属性,表示按照分组、排序结果取第一个、最后一个

把上述代码改成keep语句,只用一层嵌套子查询

sql 复制代码
select code,
       date,
       (select max(value)keep(dense_rank first order by t1.date desc)
         from test t1 
        where t.code = t1.code 
          and t1.date between date_sub(t.date,interval 1 year) and t.date 
          ) as value
  from test t
相关推荐
言德斐1 天前
SQL性能优化的思路及策略
数据库·sql·性能优化
码界奇点1 天前
Django视图从基础到高级的全面解析
数据库·django·sqlite·web·python3.11
Allan_20251 天前
数据库学习
数据库·学习
fen_fen1 天前
人大金仓数据库kingbase8创建表示例
数据库·oracle
一勺菠萝丶1 天前
「您的连接不是私密连接」详解:为什么 HTTPS 证书会报错,以及如何正确配置子域名证书
数据库·网络协议·https
²º²²এ松1 天前
蓝牙低功耗(BLE)通信的中心设备/外围设备(连接角色)、主机/从机(时序角色)、客户端/服务器(数据交互角色)的理解
运维·服务器·数据库
百锦再1 天前
Vue Scoped样式混淆问题详解与解决方案
java·前端·javascript·数据库·vue.js·学习·.net
数据库知识分享者小北1 天前
云栖重磅|瑶池数据库:从云原生数据底座向“AI就绪”的多模态数据底座演进
数据库·人工智能·云原生
_Johnny_1 天前
Redis 升级操作指南:单机与主从模式
数据库·redis·缓存
源力祁老师1 天前
ODOO数据文件(XML、CSV、SQL)是如何转换并加载到 Odoo 数据库
xml·数据库·sql