我想对以下类型的数据进行排序
ms3_fldr01
ms14_fldr01
ms13_fldr01
ms13_fldp01
ms30_fldr01
ms20_fldp01
ms9_fldr01
ms14_fldp01
ms4_fldp01
ms5_fldr01
ms1_fldp01
ms3_fldr01
ms8_fldr01这样,fldp01将首先出现,然后出现fldr01。在最早出现的fldp01 first (ms)部分的数据集中必须排序( ms1...ms10),在fldr01数据集的第一(ms)部分也必须排序。如下所示
ms1_fldp01
ms4_fldp01
ms13_fldp01
ms14_fldp01
ms20_fldp01
ms3_fldr01
ms5_fldr01
ms8_fldr01
ms9_fldr01
ms13_fldr01
ms14_fldr01
ms30_fldr01我已经尝试了下面的方法,但这并不是按照预期给出数据集。
select
server, count(*) as C
from TEST
where d_updated_date >= trunc(sysdate-4)
group by server
order by
replace(replace(server,'_fldr01'),'ms') desc,
(case when substr(server,instr(server,'_')+1)='fldp01' then 1
when substr(server,instr(server,'_')+1)='fldp02' then 2
else 0 end) desc;你能帮帮忙吗??
发布于 2017-05-06 21:32:01
您可以使用regexp_substr
select *
from test
order by regexp_substr(server, '_\w+'),
to_number(regexp_substr(server, '\d+'));发布于 2017-05-06 21:32:56
我认为这将会做你想要的:
order by (case when server like '%_fldp%' then 1 else 2 end),
length(server),
server(注意:我知道下划线在like中是一个特殊字符,但上面的仍然有效。)
这取决于_之后的零件的长度是固定的。否则,您将需要做更多的工作来分离出第一个组件。
发布于 2017-05-06 21:38:06
我期望使用普通字符串函数的解决方案优于基于正则表达式的解决方案。
SELECT *
FROM yourTable
ORDER BY
LENGTH(SUBSTR(server, INSTR(server, '_') + 1)),
SUBSTR(server, INSTR(server, '_') + 1),
LENGTH(SUBSTR(server, 1, INSTR(server, '_') - 1)),
SUBSTR(server, 1, INSTR(server, '_') - 1)https://stackoverflow.com/questions/43821015
复制相似问题