关于oracle的varchar2的比较大小的规律
2014-11-13 20:35
495 查看
oracle中字符串的比较有两类
1.填补空格的语义比较
2.非填补空格的语义比较
填补空格的语义比较:
如果两个字符串有不同的长度,oracle首先会在短的字符串那边末尾添加空格,直到两个字符串长度相等。
oracle然后按字符顺序比较两个字符串的值,如果发现到不同的字符,则按字段顺序认定大小,如果没有发现不同字符,oracle则认为两个字符串相等。这个规则意味着,如果只是尾号中有不同数目的空格,那么则认为两个字符串是相等的。如'a '='a'.
使用填补空格的语义比较,oracle只针对char,nchar,字面量,或user函数返回的值。
非填补空格的语义比较:
oracle通过字符顺序比较两个字符串的值。如果发现到字符值大的则大。如果两个字符串长度不同,则发现到字符值大的则大,否则长度大的则大,比如'b'>'ab','ab'>'a'.如果长度相等,并且各个位置字符相同,则认定为相等。
使用非填补空格的语义比较,oracle针对varchar2和nvarchar2。
1.注意使用char,char是定长类型,不足长度末尾补空格,比较大小采用填补空格的语义比较
2.注意char与其他字符连接,如
1.填补空格的语义比较
2.非填补空格的语义比较
填补空格的语义比较:
如果两个字符串有不同的长度,oracle首先会在短的字符串那边末尾添加空格,直到两个字符串长度相等。
oracle然后按字符顺序比较两个字符串的值,如果发现到不同的字符,则按字段顺序认定大小,如果没有发现不同字符,oracle则认为两个字符串相等。这个规则意味着,如果只是尾号中有不同数目的空格,那么则认为两个字符串是相等的。如'a '='a'.
使用填补空格的语义比较,oracle只针对char,nchar,字面量,或user函数返回的值。
非填补空格的语义比较:
oracle通过字符顺序比较两个字符串的值。如果发现到字符值大的则大。如果两个字符串长度不同,则发现到字符值大的则大,否则长度大的则大,比如'b'>'ab','ab'>'a'.如果长度相等,并且各个位置字符相同,则认定为相等。
使用非填补空格的语义比较,oracle针对varchar2和nvarchar2。
1.注意使用char,char是定长类型,不足长度末尾补空格,比较大小采用填补空格的语义比较
2.注意char与其他字符连接,如
declare a char(3):='ab'; b char(6):='ab'; begin dbms_output.put_line(a||'c'); --ab c 其中ab和c之间有一个空格 dbms_output.put_line(b||'c'); --ab c 其中ab和c之间有4个空格 if a||'c' >b||'c' then dbms_output.put_line(1); //成立,采用非语义比较。 end if; end;
相关文章推荐
- SSH+Oracle整个问题9 关于BigDecimal 和Int整数比较大小的问题
- Oracle 9i与MS SQL Server 2000之比较连载四:关于Oracle的Sys、System的用户与MS SQL 的master的比较
- Oracle比较两个数的大小
- 关于 char(10) 与 varchar(20) 两个类型的字段的比较 (oracle 数据库)
- 关于为什么整型不能和float,double型直接比较大小的原因
- oracle timestamp 比较大小
- 关于Sql Server中字符串比较大小写敏感的问题
- Oracle两个易错的地方,关于null和''的逻辑比较
- 关于Oracle的exp和dblink转移数据效率比较以及DBLINK查询大字段方法
- 关于Oracle中varchar2和dbms_output.put_line的长度限制问题小结
- 关于Integer大小比较的问题
- 关于不等长字符串的大小比较
- oracle sql日期比较和查看表空间大小
- 关于char和varchar2的比较
- 关于Integer大小比较的问题
- ORACLE中VARCHAR2、BOOLEAN、NUMBER的比较
- Related to Oracle SQL 关于遇到Number型与varchar2型比较时的隐式转换引起的生产问题
- 关于编写函数比较两个整数的大小的问题
- oracle char与varchar2的比较与使用
- 【转】关于Integer大小比较的问题