zoukankan      html  css  js  c++  java
  • 关于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;




  • 相关阅读:
    角学习教程
    用AngularJS指令扩展HTML
    MVC 6动态导航菜单从数据库
    从Angular5和ASP开始。网络核心
    .NET中的音乐符号
    在Blazor的音乐符号-第二部分
    ASP。NET Core 2.1:集成VMD.RESTApiResponseWrapper。REST API应用程序的核心
    AsyncHttpClient
    Mina
    Volley
  • 原文地址:https://www.cnblogs.com/JSD1207ZX/p/9386292.html
Copyright © 2011-2022 走看看