码迷,mamicode.com
首页 > 数据库 > 详细

Oracle的varchar2如何比较大小

时间:2019-11-04 17:10:14      阅读:124      评论:0      收藏:0      [点我收藏+]

标签:比较   sdn   nbsp   ali   一个   指正   width   参考资料   字符类型   

首先要说的是Oracle中字符类型的比较都是基于ASCII码表来实现的,我就简单做个总结。

Oracle中varchar2类型的字符串使用的是非填充空格的标准来进行比较的(表格中右边的那列,注意空格的情况)。

Blank-Padded 

Nonpadded
‘ac‘ > ‘ab‘  ‘ac‘ > ‘ab‘
‘ab‘ > ‘a  ‘  ‘ab‘ > ‘a   ‘
‘ab‘ > ‘a‘  ‘ab‘ > ‘a‘
‘ab‘ = ‘ab‘  ‘ab‘ = ‘ab‘
‘a ‘ = ‘a‘  ‘a ‘ > ‘a‘

 

 

 

 

 

 

 

 

在比较时(类型一致的前提下),如果长度一致,会先比较第一个字符的在ASCII码中的大小,大的那个则整个字符串大于小的那个字符串,否则就比较下一个字符,方法同此;

如果长度不一致,比较方法同上,只是存在值的字符位的值大于不存在值的,存在空格的也是把另一个字符串对应字符位的值和ASCII码中空格的值进行比较。

存在错误欢迎指正,谢谢!

参考资料(对另外的字符类型也有说明):

https://blog.csdn.net/rockpk008/article/details/41087679

https://blog.csdn.net/xiadingling/article/details/82115860

 

Oracle的varchar2如何比较大小

标签:比较   sdn   nbsp   ali   一个   指正   width   参考资料   字符类型   

原文地址:https://www.cnblogs.com/flyingorchid/p/11792943.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!