关于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)
bug怎么这么多!