運(yùn)算符優(yōu)先級確定表達(dá)式分組。這會影響一個(gè)表達(dá)式是如何進(jìn)行計(jì)算。某些運(yùn)算符的優(yōu)先級高于其他運(yùn)算符; 例如,乘法運(yùn)算符的優(yōu)先級比加法運(yùn)算高:
例如 x =7 + 3* 2; 這里,x被賦值13,而不是20,因?yàn)檫\(yùn)算符*具有優(yōu)先級高于+,所以它首先被乘以3 * 2,然后再加上7。
這里,具有最高優(yōu)先級的操作出現(xiàn)在表的頂部,那些具有最低出現(xiàn)在底部。在表達(dá)式,更高的優(yōu)先級運(yùn)算符將首先計(jì)算。
運(yùn)算符 | 操作符 |
---|---|
** | 指數(shù)運(yùn)算 |
+, - | 加法,取反 |
*, / | 乘法,除法 |
+, -, || | 加,減,并置 |
=, <, >, <=, >=, <>, !=, ~=, ^=, IS NULL, LIKE, BETWEEN, IN |
比較 |
NOT | 邏輯否定 |
AND | 關(guān)聯(lián) |
OR | 包含 |
試試下面的例子來理解運(yùn)算符優(yōu)先級在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; /
當(dāng)上述代碼在SQL提示符執(zhí)行時(shí),它產(chǎn)生了以下結(jié)果:
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.