zoukankan      html  css  js  c++  java
  • SQL记录-PLSQL运算符

    PL/SQL运算符

    运算符是一个符号,告诉编译器执行特定的数学或逻辑操作。 PL/SQL语言有丰富的内置运算符,运算符提供的以下几种类型:

    • 算术运算符

    • 关系运算符

    • 比较运算符

    • 逻辑运算符

    • 字符串运算符

    本教程将一个接一个介绍算术,关系比较和逻辑运算符。字符串运算符将在下章讨论。

    算术运算符

    下表列出了所有PL/SQL支持的算术运算符。假设变量A=10和可变B=5,则:

    运算符描述示例
    + 相加两个操作数 A + B = 15
    - 第一个操作数减去第二个操作数 A - B = 5
    * 两个操作数相乘 A * B = 50
    / 两个操作数相除 A / B = 2
    ** 乘方运算 A ** B = 100000

    示例:

    BEGIN 
       dbms_output.put_line( 10 + 5);
       dbms_output.put_line( 10 - 5);
       dbms_output.put_line( 10 * 5);
       dbms_output.put_line( 10 / 5);
       dbms_output.put_line( 10 ** 5);
    END;
    /
    

    当上述代码在SQL提示符执行时,它产生了以下结果:

    15
    5
    50
    2
    100000
    
    PL/SQL procedure successfully completed.

    关系运算符

    关系运算符比较两个表达式或值,并返回一个布尔结果。下表列出了所有PL/SQL支持的关系运算符。假设变量A=10,变量B=20,则:

    运算符描述示例
    = 检查两个操作数的值是否相等,如果是的话那么条件为真。 (A = B) 结果为 false.
    !=
    <>
    ~=
    检查两个操作数的值是否相等,如果值不相等,则条件变为真。 (A != B) 结果为 true.
    > 检查左边的操作数的值是否大于右操作数的值,如果是的话那么条件为真。 (A > B) 结果为 false.
    < 检查左边的操作数的值是否小于右操作数的值,如果是的话那么条件为真。 (A < B) 结果为 true.
    >= 检查左边的操作数的值是否大于或等于右操作数的值,如果是的话那么条件为真。 (A >= B)  结果为 false.
    <= 检查左边的操作数的值是否小于或等于右操作数的值,如果是的话那么条件为真。 (A <= B) 结果为 true.

    示例:

    DECLARE
       a number (2) := 21;
       b number (2) := 10;
    BEGIN
       IF (a = b) then
          dbms_output.put_line('Line 1 - a is equal to b');
       ELSE
          dbms_output.put_line('Line 1 - a is not equal to b');
       END IF;
    
       IF (a < b) then
          dbms_output.put_line('Line 2 - a is less than b');
       ELSE
          dbms_output.put_line('Line 2 - a is not less than b');
       END IF;
       
       IF ( a > b ) THEN
          dbms_output.put_line('Line 3 - a is greater than b');
       ELSE
          dbms_output.put_line('Line 3 - a is not greater than b');
       END IF;
    
       -- Lets change value of a and b
       a := 5;
       b := 20;
       IF ( a <= b ) THEN
          dbms_output.put_line('Line 4 - a is either equal or less than b');
       END IF;
    
       IF ( b >= a ) THEN
          dbms_output.put_line('Line 5 - b is either equal or greater than a');
       END IF;
       
       IF ( a <> b ) THEN
          dbms_output.put_line('Line 6 - a is not equal to b');
       ELSE
          dbms_output.put_line('Line 6 - a is equal to b');
       END IF;
    
    END;
    /

    当上述代码在SQL提示符执行时,它产生了以下结果:

    Line 1 - a is not equal to b
    Line 2 - a is not less than b
    Line 3 - a is greater than b
    Line 4 - a is either equal or less than b
    Line 5 - b is either equal or greater than a
    Line 6 - a is not equal to b
    
    PL/SQL procedure successfully completed

    比较运算符

    比较运算符用于一个表达比较到另一个。结果总是 TRUE,FALSE或NULL。

    运算符描述示例
    LIKE LIKE操作一个字符,字符串或CLOB值进行比较匹配模式则返回TRUE,如果不匹配模式则FALSE 如果 'Zara Ali' like 'Z% A_i' 返回一个布尔值true, 然而, 'Nuha Ali' like 'Z% A_i' 返回布尔值 false
    BETWEEN BETWEEN 运算符测试一个值是否位于规定的范围内. x BETWEEN a AND b 意思就是 x >= a and x <= b. 如果 x = 10 那么  x between 5 and 20 返回 true, x between 5 and 10 返回 true, 但是 x between 11 and 20 返回 false
    IN IN运算符的测试设置成员. x IN (set) 意味着x等于集合中的某一个成员 如果  x = 'm' then, x in ('a', 'b', 'c') 返回布尔值false,但x在('m', 'n', 'o') 返回布尔值 true.
    IS NULL IS NULL运算符返回布尔值true,如果它的操作数是NULL或FALSE(如果它不为NULL)。包括NULL值的比较总能取得NULL 如果  x = 'm', 那么 'x is null' 返回布尔值false

    LIKE 运算符:

    这个程序测试LIKE运算符,将学习如何在PL/ SQL程序使用,但这里用一个程序来显示LIKE运算符的功能:

    DECLARE
    PROCEDURE compare (value  varchar2,  pattern varchar2 ) is
    BEGIN
       IF value LIKE pattern THEN
          dbms_output.put_line ('True');
       ELSE
          dbms_output.put_line ('False');
       END IF;
    END;
    
    BEGIN
       compare('Zara Ali', 'Z%A_i');
       compare('Nuha Ali', 'Z%A_i');
    END;
    /

    当上述代码在SQL提示符执行时,它产生了以下结果:

    True
    False
    
    PL/SQL procedure successfully completed.
    

    BETWEEN运算符:

    下面的程序显示了运算符BETWEEN的用法:

    DECLARE
       x number(2) := 10;
    BEGIN
       IF (x between 5 and 20) THEN
          dbms_output.put_line('True');
       ELSE
          dbms_output.put_line('False');
       END IF;
       
       IF (x BETWEEN 5 AND 10) THEN
          dbms_output.put_line('True');
       ELSE
          dbms_output.put_line('False');
       END IF;
       
       IF (x BETWEEN 11 AND 20) THEN
          dbms_output.put_line('True');
       ELSE
          dbms_output.put_line('False');
       END IF;
    END;
    /

    当上述代码在SQL提示符执行时,它产生了以下结果:

    True
    True
    False
    
    PL/SQL procedure successfully completed.
    

    IN和IS NULL运算符:

    下面的程序显示IN和IS NULL运算符的用法:

    DECLARE
       letter varchar2(1) := 'm';
    BEGIN
       IF (letter in ('a', 'b', 'c')) THEN
          dbms_output.put_line('True');
       ELSE
          dbms_output.put_line('False');
       END IF;
     
       IF (letter in ('m', 'n', 'o')) THEN
           dbms_output.put_line('True');
       ELSE
          dbms_output.put_line('False');
       END IF;
       
       IF (letter is null) THEN
        dbms_output.put_line('True');
       ELSE
          dbms_output.put_line('False');
       END IF;
    END;
    /

    当上述代码在SQL提示符执行时,它产生了以下结果:

    False
    True
    False
    
    PL/SQL procedure successfully completed.

    逻辑运算符

    下表显示了PL/SQL支持的逻辑运算符。所有这些操作符布尔运算,并产生布尔结果。假设变量A=true,变量B=false,那么:

    运算符描述示例
    and 称为逻辑AND运算。如果两个操作数为true,则条件为true (A and B) 结果为 false.
    or 所谓的逻辑或操作。如果任何两个操作数为true,则条件变为true (A or B) 结果为 true.
    not 所谓逻辑非运算符。用于反向操作数的逻辑状态。如果条件为true,那么逻辑非运算符将使它为false not (A and B) 结果为 true.

    运算符:

    DECLARE
       a boolean := true;
       b boolean := false;
    BEGIN
       IF (a AND b) THEN
          dbms_output.put_line('Line 1 - Condition is true');
       END IF;
       IF (a OR b) THEN
          dbms_output.put_line('Line 2 - Condition is true');
       END IF;
       IF (NOT a) THEN
          dbms_output.put_line('Line 3 - a is not true');
       ELSE
          dbms_output.put_line('Line 3 - a is true');
       END IF;
       IF (NOT b) THEN
          dbms_output.put_line('Line 4 - b is not true');
       ELSE
          dbms_output.put_line('Line 4 - b is true');
       END IF;
    END;
    /

    当上述代码在SQL提示符执行时,它产生了以下结果:

    Line 2 - Condition is true
    Line 3 - a is true
    Line 4 - b is not true
    
    PL/SQL procedure successfully completed.

    PL/SQL运算符优先级

    运算符优先级确定表达式分组。这会影响一个表达式是如何进行计算。某些运算符的优先级高于其他运算符; 例如,乘法运算符的优先级比加法运算高:

    例如 x =7 + 3* 2; 这里,x被赋值13,而不是20,因为运算符*具有优先级高于+,所以它首先被乘以3 * 2,然后再加上7。

    这里,具有最高优先级的操作出现在表的顶部,那些具有最低出现在底部。在表达式,更高的优先级运算符将首先计算。

    运算符操作符
    ** 指数运算
    +, - 加法,取反
    *, / 乘法,除法
    +, -, || 加,减,并置
    =, <, >, <=, >=, <>, !=, ~=, ^=, 
    IS NULL, LIKE, BETWEEN, IN
    比较
    NOT 逻辑否定
    AND 关联
    OR 包含

    示例:

    试试下面的例子来理解运算符优先级在PL/ SQL中的使用:

    DECLARE
       a number(2) := 20;
       b number(2) := 10;
       c number(2) := 15;
       d number(2) := 5;
       e number(2) ;
    BEGIN
       e := (a + b) * c / d;      -- ( 30 * 15 ) / 5
       dbms_output.put_line('Value of (a + b) * c / d is : '|| e );
    
       e := ((a + b) * c) / d;   -- (30 * 15 ) / 5
       dbms_output.put_line('Value of ((a + b) * c) / d is  : ' ||  e );
    
       e := (a + b) * (c / d);   -- (30) * (15/5)
       dbms_output.put_line('Value of (a + b) * (c / d) is  : '||  e );
    
       e := a + (b * c) / d;     --  20 + (150/5)
       dbms_output.put_line('Value of a + (b * c) / d is  : ' ||  e );
    END;
    /
    

    当上述代码在SQL提示符执行时,它产生了以下结果:

    Value of (a + b) * c / d is : 90
    Value of ((a + b) * c) / d is  : 90
    Value of (a + b) * (c / d) is  : 90
    Value of a + (b * c) / d is  : 50
    
    PL/SQL procedure successfully completed.
  • 相关阅读:
    注释驱动的 Spring cache 缓存介绍--转载
    AOP 的利器:ASM 3.0 介绍
    字符串比较报错
    Performing a thread dump in Linux or Windows--reference
    Linux 精准获取进程pid--转
    /bin/bash^M: bad interpreter: 没有那个文件或目录--转载
    linux 进程综合指令
    Sending e-mail with Spring MVC---reference
    Spring XD 1.1 M2 and 1.0.3 released---support kafka
    大数据框架对比:Hadoop、Storm、Samza、Spark和Flink——flink支持SQL,待看
  • 原文地址:https://www.cnblogs.com/xinfang520/p/7717984.html
Copyright © 2011-2022 走看看