关于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)

 

posted @ 2020-02-22 11:31  changlinlo  阅读(552)  评论(0编辑  收藏  举报