急!!请教如果排序

会飞的小洋洋 2007-05-06 11:50:18
varchar(100)的一个数据列,含数据'B01-09-03','10003-02-01','1-1-3','A02-02-01','A02-02-02','1-1-4'

得到一个顺序结果
'1-1-3'
'1-1-4'
'10003-02-01'
'A02-02-01'
'A02-02-02'
'B01-09-03'
...全文
284 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
lwl0606 2007-05-07
  • 打赏
  • 举报
回复
强,学习一下
肥胖的柠檬 2007-05-07
  • 打赏
  • 举报
回复
order by 后机可以加 case,查询,函数的
会飞的小洋洋 2007-05-07
  • 打赏
  • 举报
回复
这个是什么原理?太简单了吧。会不会有不满足的?
会飞的小洋洋 2007-05-07
  • 打赏
  • 举报
回复
To:chuifengde(树上的鸟儿) 厉害
---涛声依旧--- 2007-05-07
  • 打赏
  • 举报
回复
樓上正解
chuifengde 2007-05-06
  • 打赏
  • 举报
回复
set nocount on
declare @a table(a varchar(100))
insert @a select 'B01-09-03'
insert @a select '10003-02-01'
insert @a select'1-1-3'
insert @a select'A02-02-01'
insert @a select'A02-02-02'
insert @a select'1-1-4'

select * from @a order by case when isnumeric(left(a,1)) =1 then charindex('-',a) else 20 end,a
gahade 2007-05-06
  • 打赏
  • 举报
回复
--结果
/*
istr
--------------
'1-1-3'
'1-1-4'
'10003-02-01'
'A02-02-01'
'A02-02-02'
'B01-09-03'

(所影响的行数为 6 行)

*/
gahade 2007-05-06
  • 打赏
  • 举报
回复
CREATE function udf_splitstring
(
@str varchar(8000) --要分拆的字符串
,@spli varchar(10) --字符串分隔符
)
returns @retab table(istr varchar(8000))
as
begin
declare @i int
declare @splen int
select @splen=len(@spli),@i=charindex(@spli,@str)
while @i > 0
begin
insert into @retab
values(left(@str,@i-1))
select @str=substring(@str,@i+@splen,8000)
select @i=charindex(@spli,@str)
end
if @str<>'' insert into @retab values(@str)
return
end
GO

select istr
from udf_splitstring('''B01-09-03'',''10003-02-01'',''1-1-3'',''A02-02-01'',''A02-02-02'',''1-1-4''',',')
order by left(istr,charindex('-',istr)-1)

34,576

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧