Oracle中对数字加汉字的排序(完好)

时间:2023-11-11 22:03:08

之前写过一篇 Oracle中对数字加汉字的排序以及REGEXP_SUBSTR介绍

后来在开发的过程中又遇到相似问题。数据不一样了,按之前的使用方法是不适用的。

之前的是数字在前汉字在后,最基本的差别是数字没有反复的,而如今的数据中数字是有反复的

比方:

玫瑰园1楼
玫瑰园2楼
兴帝家园1楼
兴帝家园2楼

假设是仅仅抽取数字进行排序 会造成两个1楼在前 两个2楼在后

而想要的结果是先按同样的名字排序 再按楼号排序

第一步:截取汉字

仅仅截取正則表達式中汉字首次出现的位置(下同)

REGEXP_SUBSTR(name, '[[:alpha:]]+')

第二步:截取数字

REGEXP_SUBSTR(name, '[0-9]+')

第三步:ORDER BY排序

先按汉字进行排序,同样的再按数字排序

SELECT * FROM ADDRESS_TREE
order by REGEXP_SUBSTR(name, '[[:alpha:]]+'), --汉字排序
cast(REGEXP_SUBSTR(name, '[0-9]+') as int); --数字排序

Oracle中对数字加汉字的排序(完好)

作者:itmyhome