order by居然不能直接在union子句中使用

简介:

今天一个群中的兄弟问一个问题,说有一个表,表中有很多数据,其中有个字段type,希望从表中随机取出10条记录,其中有5条type=1另外5条type=0,比如下图这样:

image

我一想,这还不简单,按照要求,每个取top 5,既然是随机的取,那么就order by newid()就是了三,然后把所有数据union起来就得了。所以我立即给出了答案:

select top 5 * from xxx where type=1 order by newid()

union

select top 5 * from xxx where type=0 order by newid()

但是那个兄弟说不对,语法有错,我乍一看,好像没有问题把,于是让他把表定义发给我,我在本机试一下,表定义是:

CREATE TABLE [dbo].[Question](
[id] [int] IDENTITY(1,1) NOT NULL,
[question] [varchar](50) NOT NULL,
[answer] [varchar](50) NOT NULL,
[type] [bit] NOT NULL,
CONSTRAINT [PK_Question] PRIMARY KEY CLUSTERED
(
[id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

于是将我的语句输进SSMS,结果系统还真是报错了:Incorrect syntax near the keyword 'ORDER'.

怎么回事啊?怎么看也不像有问题的啊。于是我单独执行

select top 5 * from dbo.Question
where [type]=1
ORDER BY newid()

对的啊。没有问题,下面的半句也是一样的语法结构,也没有错误。但是把这两个查询union起来就错了。奇怪啊。既然提示是order附近有错,那么我将order给去掉:

(select top 5 * from dbo.Question
where [type]=1
)
UNION
(select top 5 * from dbo.Question
where [type]=0
)

也没有错啊。也就是说在union子句中的查询不能用order by。但是这儿我必须要用order by啊,要不然我怎么取出随机的5条记录?不用union可以不?可以啊,创建一个临时表,将查询出来的5条数据插进去,另外5条也是。然后再查询临时表,但是能不使用临时表就尽量不要使用临时表,何必弄的那么复杂。

又要用order by 又要用union,怎么办?order by不能直接出现在union的子句中,但是可以出现在子句的子句中啊!于是查询最终改写成了:

SELECT * FROM
(select TOP(5) * from dbo.Question where [type]=1 ORDER BY newid() ) t1
UNION
SELECT * FROM
(select TOP(5) * from dbo.Question where [type]=0 ORDER BY newid()) t2

感觉有点别扭,但是没法,不知道为什么SQL Server中不能在union子句中使用order by,所以只有出此下策了。
目录
相关文章
|
7月前
|
测试技术
Squaretest自动生成单元测试
Squaretest自动生成单元测试
190 8
Squaretest自动生成单元测试
|
7月前
|
人工智能 JSON 自然语言处理
AI 程序员的4个分身 | 代码生成专家+注释精灵+API集成助手+智能调试伙伴
AI 程序员的4个分身 | 代码生成专家+注释精灵+API集成助手+智能调试伙伴
347 35
|
10月前
|
网络协议 SDN 数据中心
VXLAN的应用场景
VXLAN技术用于云数据中心间虚拟机迁移,确保迁移过程中业务连续性和网络无感知。通过在虚拟机上联交换机配置VXLAN信息,建立VXLAN隧道和网关,实现跨数据中心的大范围二层网络连接。在SDN环境下,SDN控制器可管理VXLAN的IP和VID对应关系,提高灵活性与扩展性。
330 3
|
11月前
|
运维 网络性能优化 网络虚拟化
|
弹性计算 固态存储 数据可视化
阿里云服务器一年价格2023最新价格明细来了
阿里云服务器一年价格2023最新价格明细来了。阿里云服务器分为云服务器ECS和轻量应用服务器,云服务器s6公网带宽可选1M到5M,系统盘40G起可选高效云盘、SSD云盘或ESSD云盘,1核1G配置19.17元3个月、306.72元一年,1核2G优惠价26.46元3个月、423.36元一年,2核4G配置42.66元3个月,2核8G配置58.86元3个月,4核8G 75.06元3个月,8核16G 139.86元3个月,还有4核16G、8核32G多配置可选。不只是云服务器ECS共享型s6实例,ECS计算型c6、通用型g6、内存型r6、云服务器u1、企业级c7/g7/r7系列、轻量应用服务器和GPU云
858 0
|
Android开发 Kotlin
kotlin开发安卓应用 如何修改app安装后的名称
在 Android 应用中,要修改安装后的显示名称,需更新 AndroidManifest.xml 文件中 application 标签的 android:label 属性。可直接在该属性内设置新名称,或在 res/values/strings.xml 文件中修改 app_name 并在 manifest 中引用。推荐使用 strings.xml 方式,以便支持多语言和集中管理。
|
存储 运维 Kubernetes
基于rancher部署k8s及使用
基于rancher部署k8s及使用
777 2
|
存储 Linux Android开发
Rockchip u-boot阶段命令行和代码方式读取u盘内容并解析
Rockchip u-boot阶段命令行和代码方式读取u盘内容并解析
2020 2
|
Linux Perl
如何在Linux中高效查找大文件
在Linux中查找大文件的方法包括使用find(如`find /path/to/search -size 100M`查找100MB文件),du(如`du -ah /path/to/search | awk '$1 ~ /M$/ && $1 > 100 {print}'`查找大于100MB的文件),ls结合排序(如`ls -lhS /path/to/search | head -n 10`显示最大10个文件)和GUI工具(Nautilus、Thunar等)。选择方法要考虑查找范围、结果需求和用户熟悉程度。注意权限和验证结果,参考相关文档以获取更多帮助。
1297 0
|
人工智能 安全
编程利器Boit 使用详解
利用ai编程利器Boit 提高开发效率
361 0