首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >WinSQL ORDER BY字母数字DB2语法

WinSQL ORDER BY字母数字DB2语法
EN

Stack Overflow用户
提问于 2018-08-03 21:45:29
回答 1查看 147关注 0票数 0

我有以下一组数据:

代码语言:javascript
复制
33
5A
5B
12
34A
2
34B
2B
11
10
12A

当我在WinSQL中运行以下SQL时:

代码语言:javascript
复制
with input (f) as ( 
values ('33'), ('5A'), ('5B'),('12'), ('34A'),('2'), ('34B'), ('2B'), ('11'), ('10'), ('12A')
  )
SELECT f 
FROM input
ORDER BY f

我得到了以下结果:

代码语言:javascript
复制
10
11
12
12A
2
2B
33
34A
34B
5A
5B

然而,我希望结果是这样的:

代码语言:javascript
复制
2
2B
5A
5B
10
11
12
12A
33
34A
34B

我尝试过以下几种方法:

代码语言:javascript
复制
with input (f) as ( 
    values ('33'), ('5A'), ('5B'),('12'), ('34A'),('2'), ('34B'), ('2B'), ('11'), ('10'), ('12A')
  )
SELECT 
f
FROM input
ORDER BY CAST(CASE
                 WHEN f LIKE '[0-9]' THEN LEFT(CONCAT(0,f),1)
                 WHEN f LIKE '[0-9]%' THEN LEFT(CONCAT(0,f),1)
                 WHEN f LIKE '[0-9][0-9]%' THEN LEFT(f ,2)
                 ELSE NULL 
              END AS INT), f

但它不起作用。

注意:这是针对DB2的,并且所有SQL服务器函数(如PATINDEX、SIGNED/UNSIGNED)都不可用。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-04 22:36:55

试试这个:

代码语言:javascript
复制
ORDER BY CAST(replace(replace(replace(f,'A',''),'B',''),' ','') AS INT), f

(例如,通过去除非数字元素并转换为数字,然后使用原始值打破平局来构造排序字段)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51674078

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档