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)