关于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 @   changlinlo  阅读(582)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
点击右上角即可分享
微信分享提示