sql执行报错:除非另外还指定了 TOP,OFFSET 或FOR XML,否则,ORDER BY 子句在视图,内联函数,派生表子查询和用表表达式中无效

这个异常信息已经说的很清楚了,要解决这个问题只能指定TOP,可是这个变态的接口需要的是没有TOP条数的SQL,怎么办呢?

当时想啊,思路有两个:

1.查询的时候加一个ROW_NUMBER,这样就能达到查询出的结果是按自己的意愿排序了,但数据量大可能不适用。

事实证明这样是可行的,需要的语句是这样的:

select ROW_NUMBER() over(order by name) as rn,* from Movie;

2.还是添加TOP,但是要TOP所有的记录条数。

这个有个难点,怎么获得所有的记录条数呢?

在查阅资料的时候发现了一个写了这么写年的SQL却从来没用过,也没听人提起过,学习SQL时也未曾发现的好东东啊

TOP 100 PERCENT

当然也可以是其他的百分比,不过这个100 PERCENT, 正好解决了我的问题。

于是我的SQL可以是这样的:

select top 100 percent * from Movie order by name;

总结:这样就有两个知识点了

1.子查询中不能有ORDER BY, 除非指定了TOP;

2.TOP后面可以跟百分比,如:TOP 35 PERCENT;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值