表名 T_LABEL,存储结构如下
ID Label
1 ABC
2 CBD
3 AC
4 BC
5 BB
6 BC
7 AA
9 BB
10 BA
查询要求:
1.按首字母升序排列。例如首字母为A的纪录在排在最前。
2.完全相同的按照ID降序排列,例如ID = 5,LABEL = BB,ID = 9,LABEL = BB,则排列后ID = 9的纪录排在ID = 5的纪录前。
3.其他的按照原顺序不变 例如ID = 3,LABEL = AC和ID = 7, LABEL = AA 两条纪录,AC 排在AA 前。
根据规则,上面的存储结构根据可由一条查询语句实现,结果为
ID Label
1 ABC
3 AC
7 AA
6 BC
4 BC
9 BB
5 BB
10 BA
2 CBD
郁闷,这是道面试题。
--------------------------------------------------------------
下面为答案
zjcxc(邹建):
select * from tb a
order by
left(label,1), -- 首字母升序
case when exists(select * from tb where label=a.label) then id else - id end desc
samfeng_2003(凤翼天翔) :
declare @t table
(id int,label varchar(10))
insert @t
select 1,'ABC' union all
select 2,'CBD' union all
select 3,'AC' union all
select 4,'BC' union all
select 5,'BB' union all
select 6,'BC' union all
select 7,'AA' union all
select 9,'BB' union all
select 10,'BA'
select * from @t a
order by
left(label,1),
case when label in (select label from @t group by label having count(*)>1)
then label+'0'+cast(id as varchar) end desc
id label
----------- ----------
1 ABC
3 AC
7 AA
6 BC
4 BC
9 BB
5 BB
10 BA
2 CBD
(所影响的行数为 9 行)
本文介绍了一种复杂的SQL排序方法,该方法能实现首字母升序排列,并在遇到相同标签时按ID降序排列,同时保持其他记录的原始顺序不变。通过使用CASE WHEN语句和LEFT函数,可以高效地实现这一需求。
2216

被折叠的 条评论
为什么被折叠?



