社区
疑难问题
帖子详情
关于order by (case when 条件1 then 字段1 else 字段3),字段1,字段2,字段3)
huxin1
2004-01-27 06:26:01
请蒋老师、马可、邹建帮讲解一下它的排序规律是怎样的,好吗?我实在想不明白。最好从原理上分析一个,算我求你们了。
...全文
1383
6
打赏
收藏
关于order by (case when 条件1 then 字段1 else 字段3),字段1,字段2,字段3)
请蒋老师、马可、邹建帮讲解一下它的排序规律是怎样的,好吗?我实在想不明白。最好从原理上分析一个,算我求你们了。
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
6 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
jyk1970
2004-01-27
打赏
举报
回复
create table tt
(
bmid int,
boardid int,
parentid int
)
insert into tt values(1, 1, 9)
insert into tt values(2, 2, 17)
insert into tt values(5, 3, 18)
insert into tt values(9, 0, 0)
insert into tt values(15, 0, 0)
insert into tt values(16, 4, 17)
insert into tt values(17, 0, 0)
insert into tt values(18, 0, 0)
insert into tt values(5, 3, 18)
go
--你的方法
select * from tt order by (case when parentid=0 then bmid else parentid end),parentid,bmid,boardid;
--等效的方法
select (case when parentid=0 then bmid else parentid end) as myid, *
from tt
order by myid,parentid,bmid,boardid
--结果必然是
myid bmid boardid parentid
----------- ----------- ----------- -----------
9 9 0 0
9 1 1 9
15 15 0 0
17 17 0 0
17 2 2 17
17 16 4 17
18 18 0 0
18 5 3 18
18 5 3 18
huxin1
2004-01-27
打赏
举报
回复
大家还是没有明白我的意思,还是举例说明吧
有这样一个表tt(bmid int,boardid int,parentid int)
如果用select * from tt;结果集如下:
bmid boardid parentid
----------- ----------- -----------
1 1 9
2 2 17
5 3 18
9 0 0
15 0 0
16 4 17
17 0 0
18 0 0
5 3 18
(所影响的行数为 9 行)
而用select * from tt order by (case when parentid=0 then bmid else parentid end),parentid,bmid,boardid;结果集如下:
bmid boardid parentid
----------- ----------- -----------
9 0 0
1 1 9
15 0 0
17 0 0
2 2 17
16 4 17
18 0 0
5 3 18
5 3 18
(所影响的行数为 9 行)
我不明白的是第二种情况为什么不是以下这种情况呢?
bmid boardid parentid
----------- ----------- -----------
9 0 0
15 0 0
17 0 0
18 0 0
1 1 9
2 2 17
16 4 17
5 3 18
5 3 18
(所影响的行数为 9 行)
zhaoloudy
2004-01-27
打赏
举报
回复
mark
Jianli2004
2004-01-27
打赏
举报
回复
order by (case when 条件1 then 字段1 else 字段3),字段1,字段2,字段3)
应该是
order by (case when 条件1 then 字段1 else 字段3 end),字段1,字段2,字段3)
在条件1下按字段1其他情况下按字段3排序
huxin1
2004-01-27
打赏
举报
回复
楼上的大哥,这些我是知道的,我是搞不明白我提出的这种情况。最好拿实例来讲解。
azsoft
2004-01-27
打赏
举报
回复
语法
[ ORDER BY { order_by_expression [ ASC | DESC ] } [ ,...n ] ]
参数
order_by_expression
指定要排序的列。可以将排序列指定为列名或列的别名(可由表名或视图名限定)和表达式,或者指定为代表选择列表内的名称、别名或表达式的位置的负整数。
可指定多个排序列。ORDER BY 子句中的排序列序列定义排序结果集的结构。
ORDER BY 子句可包括未出现在此选择列表中的项目。然而,如果指定 SELECT DISTINCT,或者如果 SELECT 语句包含 UNION 运算符,则排序列必定出现在选择列表中。
此外,当 SELECT 语句包含 UNION 运算符时,列名或列的别名必须是在第一选择列表内指定的列名或列的别名。
说明 在 ORDER BY 子句中不能使用 ntext、text 和 image 列。
ASC
指定按递增顺序,从最低值到最高值对指定列中的值进行排序。
DESC
指定按递减顺序,从最高值到最低值对指定列中的值进行排序。
空值被视为最低的可能值。
对 ORDER BY 子句中的项目数没有限制。然而,对于排序操作所需的中间级工作表的大小有 8,060 字节的限制。这限制了在 ORDER BY 子句中指定的列的合计大小。
【sql】
order
by
case
when then end总结
举个简单的例子: 例子1 select * from xxxx
order
by (
case
when status=3 then 1 else 4 end),id; status和id为xxxx表中的一个
字段
,其中(
case
when status=3 then 1 else 4 end)代表根据status
字段
值生成的新的一列,如果
字段
status值为3则新列对应的值为1,否者新列对应的值为4。 此语句排序意思为先按照生成的列正序,然后在按照id列排序。 例子2 select * from xxxx
在
order
by中使用
case
when实现自定义排序 2020-08-17
对于
order
by排序的时候不仅仅可以desc和asc,还可以自定义排序 select * from 表名
order
by 排序
字段
1, (
case
排序
字段
2 when
条件
1 then 0 --当排序
字段
2=
条件
1,则将起排在第0位 when
条件
2 then 1 --当排序
字段
2=
条件
2,则将起排在第1位 when
条件
2 then 2 --当排序
字段
2=
条件
3,则将起排在第2位 end) ...
【MySQL】
order
by 高级用法
case
when (
字段
多值自定义排序)
order
by 高级用法
case
when (
字段
多值自定义排序)
sql语句
ORDER
BY 使用的
CASE
WHEN 函数
sql语句
ORDER
BY 使用的
CASE
WHEN 函数1.准备工作2.需求3. sql语句如写的不正确,请各位大佬帮忙指点!谢谢各位!! 首先说明一下 在
order
by 中
case
when then并不会修改值,只是给数据做一下标识;下面我们将用sql语句来验证 1.准备工作 2.需求 将type为1的值先输出,并按照时间倒序;其余的按照时间倒序即可 3. sql语句 SELECT * FROM employee
ORDER
BY
CASE
WHEN `type`=1 THEN 0
Oracle的
order
by
case
when
order
by
CASE
WHEN ref.IS_TOP=1 THEN 1 ELSE 0 END DESC 我用一个例子来解释这个问题,用到了Oracle自带的用户scott下的emp表 SQL> SELECT EMPNO, ENAME, DEPTNO FROM SCOTT.EMP A
ORDER
BY
CASE
WHEN A.DEPTNO = 20...
疑难问题
22,302
社区成员
121,735
社区内容
发帖
与我相关
我的任务
疑难问题
MS-SQL Server 疑难问题
复制链接
扫一扫
分享
社区描述
MS-SQL Server 疑难问题
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章