关于oracle的varchar2的比较大小的规律

oracle中字符串的比较有两类

    1.
填补空格的语义比较
    2.
非填补空格的语义比较

   
填补空格的语义比较:

   
如果两个字符串有不同的长度,oracle首先会在短的字符串那边末尾添加空格,直到两个字符串长度相等。

    oracle
然后按字符顺序比较两个字符串的值,如果发现到不同的字符,则按字段顺序认定大小,如果没有发现不同字符,oracle则认为两个字符串相等。这个规则意味着,如果只是尾号中有不同数目的空格,那么则认为两个字符串是相等的。如'a '='a'.

   
使用填补空格的语义比较,oracle只针对char,nchar,字面量,或user函数返回的值。

   
非填补空格的语义比较:

    oracle
通过字符顺序比较两个字符串的值。如果发现到字符值大的则大。如果两个字符串长度不同,则发现到字符值大的则大,否则长度大的则大,比如'b'>'ab','ab'>'a'.如果长度相等,并且各个位置字符相同,则认定为相等。

    使用非填补空格的语义比较,oracle针对varchar2nvarchar2


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;




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值