本文主要是介绍问题解决:除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 问题场景
- 问题环境
- 问题原因
- 解决方案
- 结果
- 总结
- 随缘求赞
问题场景
因为项目需要,需要在公共框架里面引入sqlserver
方言类。而在实现sqlserver
方言类之后,调用方言类的方法的时候,发现一个错误
错误提示如下:
>[错误] 脚本行:1-10 --------------------------------------Id 1033, Level 15, State 1, Line 10除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效。消息: 1033, 级别: 15, 状态: 1, 过程: , 行: 10
运行的SQL
如下:
SELECT COUNT(*)
FROM ( SELECT wf.S_VER AS "S_VER"FROM ( SELECT DISTINCT(S_VER)FROM testWHERE 1=1 AND I_COMMON = 1 ) AS wf ORDER BYwf.S_VER ASC
) a
问题环境
软件 | 版本 |
---|---|
SqlServer | 2008 |
问题原因
从问题的提示,我们可以看出,我们执行的SQL
内部含有order by
关键字,而且是在子查询等情况使用了该关键字,导致了数据库引擎认为该SQL
有问题,所以报错了。
解决方案
这个时候,我们可以使用top
关键字来规避这个问题。而top
关键字有两种方法使用:
-
指定具体数目
我们可以用具体的数字里进行限量获取,这个和mysql
的limit
关键字有点像。这里用一个sql
来展示从表中获取第20个之后的10个数据:SELECT TOP 10 * FROM test2 WHERE id NOT IN( SELECT top 20 id FROM test2 )
-
指定具体百分比
如果我们的sql
需要获取全部数据来做过滤,又不知道具体的数目,这个时候就可以用百分比来进行获取,其表达形式为TOP N percent
,N
为百分比数目,百分比值必须介于 0 到 100 之间,不然会报错。像我们文章开头说的问题SQL
,就需要使用这个,经过修正之后,SQL
如下:SELECT COUNT(*) FROM ( SELECT top 100 percent wf.S_VER AS "S_VER"FROM ( SELECT DISTINCT(S_VER)FROM DWF_DE_WF WHERE 1=1 AND I_COMMON = 1 ) AS wf ORDER BYwf.S_VER ASC ) a
结果
经过修正之后,sql
执行结果如下:
>[SQL] 脚本行:1-10 -------------------------------------SELECT COUNT(*) FROM ( SELECT top 100 percent wf.S_VER AS "S_VER"FROM ( SELECT DISTINCT(S_VER)FROM DWF_DE_WF WHERE 1=1 AND I_COMMON = 1 ) AS wf ORDER BYwf.S_VER ASC) a column1 ---------- 14 已选定 1 条记录 [抓取元数据:0ms] [抓取数据:0ms] [已执行:2020-6-9 下午1:35:03] [执行:4ms]
总结
这个是sqlserver
的小知识点,主要是通过这个问题,引出对top
关键字的使用。
随缘求赞
如果我的文章对大家产生了帮忙,可以在文章底部点个赞或者收藏;
如果有好的讨论,可以留言;
如果想继续查看我以后的文章,可以点击关注
可以扫描以下二维码,关注我的公众号:枫夜之求索阁,查看我最新的分享!
这篇关于问题解决:除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!