oracle数据库中,字段数据类型是varchar2类型即string,而实际存储的是数字,这时候根据order by 对数字进行排序

oracle数据库中,字段数据类型是varchar2类型即string,而实际存储的是数字,这时候根据order by 对数字进行排序

如果根据order by 直接进行排序的换可能导致在排序的过程中数字大于9的可能存在排序错误比如
11排在了9前面,因为是根据数据库中varchar2排序的(这样1肯定是在9前面),而不是根据数字的实际大小排序的
这时候可以使用orale的sql关键字:cast,将varchar2 先转换成int类型,但前提是被cast的字段,肯定是数字的形式,而不能是非数字的值,不然会报“无效的数字”错误。

   ![在这里插入图片描述](https://img-blog.csdnimg.cn/20190622164910719.png
   cast关键字会提醒你需要你转变得字段和转换的类为什么类型
   
   ![在这里插入图片描述](https://img-blog.csdnimg.cn/20190622165504447.png)
   执行后sql会将里面对应的字段SINGN_BODY_SORT 由String 转化为 int类型的进行升序
   
   ![在这里插入图片描述](https://img-blog.csdnimg.cn/2019062216580697.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1lvbmdRaWFuZ0RpdmU=,size_16,color_FFFFFF,t_70)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值