关于oracle小数和整数混合排序错误问题

一.order by

  试过order by没用

二.正则表达式

  1.对整数的

order by to_number(regexp_substr(字段名,'[0-9]*[0-9]',1))

  2.既有整数又有小数

order by to_number(regexp_substr(字段名,'(((d).d+)|(d+.(d)|d+))',1))

  以上都没用的情况下

三.方法(有小数 有整数 有符号的情况下)

我使用 case when 将符号提出来   

order by to_number(case when instr(你的字段,'数据中含有哪些字符如~*&@#')>0 then to_number(substr(你的字段,1,instr(你的字段,'数据中含有哪些符号如~*&@#')-1))+0.00001 else to_number(你的字段) end)

例如

order by to_number(case when instr(区间,'~')>0 then to_number(substr(区间,1,instr(区间,'~')-1))+0.00001 else to_number(区间) end)
原文地址:https://www.cnblogs.com/lin02/p/12344656.html