派生表oracle,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效怎么解决?-Oracle...

sql:除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询

执行sql语句:

select * from (

select * from tab where ID>20 order by userID desc

) as a order by date desc

逻辑上看着挺对 但是报错:

除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效。

只要我们在嵌套子查询视图里面加入: top 100 percent 即可

select * from (

selecttop 100 percent* from tab where ID>20 order by userID desc

) as a order by date desc

默认情况下,如果在子查询,函数,视图中尝试去使用ORDER BY,

CREATE VIEW dbo.VSortedOrders

AS

SELECT orderid, customerid

FROM dbo.Orders

ORDER BY orderid

GO

那么可能会遇到下面的错误

消息 1033,级别 15,状态 1,第 4 行

除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效。

原因就是针对一个表的SELECT其实并不是返回一个表,而是一个游标。

如果一定要用怎么办呢?答案就是配合TOP 100 PERCENT

SELECT TOP (100) PERCENT orderid, customerid

FROM dbo.Orders

ORDER BY orderid, customerid DESC

select top (100) PERCENT意思是返回符合条件所有的记录,select top 100就是返回前一百条符合条件的记录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值