您好,UncleToo欢迎您!  为了更好的浏览本站,请使用高版本浏览器
RSS  Tag     设为首页 | 加入收藏
 您所在的位置:首页 > 数据库技术 > Oracle

Oracle中对数字加汉字的排序

作者:itmyhome  来源:转载  日期:2015-12-21 22:19:39
收藏  评论:( 0 )  阅读:10

示例数据:

     玫瑰园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);   --数字排序



除非特别声明,本站所有PHP教程及其他教程/文章均为原创、翻译或网友投稿,版权均归UncleToo中文网所有, 转载请注明作者及出处。
原文网址:http://www.uncletoo.com/html/oracle/1145.html
读完这篇文章后,你是否有所收获? 分享是一种生活的信念!
  • 0
  • 0
我来说两句
更多>>网友评论