SQL语句中UNION排序问题

表A如下3个字段ID序号软件名称软件简介在搜索时先检查软件名称中是否有关键字,然后再检查软件简介.我是这样写的select*from表Awhere软件名称like'%迅雷... 表A如下3个字段
ID序号 软件名称 软件简介

在搜索时先检查软件名称中是否有关键字,然后再检查软件简介.
我是这样写的
select * from 表A where 软件名称 like '%迅雷%'
union
select * from 表A where 软件简介 like '%迅雷%'
但是查询输出时是按照默认索引列ID进行排列的
如何能实现按照语句中的优先级排列?也就是说优先显示第一条查询语句查到的结果,之后才是第二条语句的结果,而不是把所有记录集合到一起后混排.
补充下 数据库是ACCESS
展开
 我来答
tjrmgs
2012-09-19 · TA获得超过5765个赞
知道大有可为答主
回答量:2161
采纳率:94%
帮助的人:1041万
展开全部
代码改写如下:
select a.输出字段1, a.输出字段2, a.输出字段3, ...a.输出字段n from
(select * ,1 as px from 表A where 软件名称 like '%迅雷%'
union
select * ,2 from 表A where 软件简介 like '%迅雷%') a order by a.px

如果不在意多出一个用于排序的字段“px”的话,代码可简化如下
select * ,1 as px from 表A where 软件名称 like '%迅雷%' order by 1
union
select * ,2 from 表A where 软件简介 like '%迅雷%'

***注意,因人为增加了一个排序用数字字段(第一个查询用1,第二个用2),UNION关键字的删除两个查询之间重复数据的功能会不起作用,如果需要保持删除重复记录的能力,则需要使用DISTINC关键字,例如:
select distinct a.输出字段1, a.输出字段2, a.输出字段3, ...a.输出字段n from
(select * ,1 as px from 表A where 软件名称 like '%迅雷%'
union
select * ,2 from 表A where 软件简介 like '%迅雷%') a order by a.px

上机试一试吧
这是有科学依据的
2012-09-19
知道答主
回答量:16
采纳率:0%
帮助的人:4.9万
展开全部
请看一楼回答
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式