orientdb数据库-PL/SQL运算符优先级

跨零代码为大家提供高品质的解决方案,请大家多多来访,跨零不胜感激,在此谢过。

运算符优先级决定表达式中术语的分组。这会影响表达式的评估求值顺序。某些运算符的优先级高于其他运算符; 例如,乘法运算符的优先级高于加法运算符。

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

在这里,优先级最高的运算符出现在表的顶部,最底层的运算符出现在底部。在一个表达式中,将首先评估求值较高优先级的运算符。

运算符的优先级如下:=<><=>=<>!=〜=^=IS NULLLIKEBETWEENIN

运算符优先级示例

运算符 操作描述
** 指数幂运算符
+, - 标识符,负数
*, / 乘法,除法
+, -, ΙΙ 加,减,连接
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. 

  

从零到一,创造未来!跨零综合IT问题解决服务站,欢迎你的到来。Oracle数据库教程 plsql数据库/a> 只为你绽放。

本文固定链接: http://kua0.com/2019/05/06/orientdb数据库-pl-sql运算符优先级/

为您推荐

发表评论

电子邮件地址不会被公开。 必填项已用*标注