變量和常量
變量存放在內(nèi)存中以獲得值,能被PL/SQL塊引用。你可以把變量想象成一個(gè)可儲(chǔ)藏東西的容器,容器內(nèi)的東西是可以改變的。
聲明變量 變量一般都在PL/SQL塊的聲明部分聲明,PL/SQL是一種強(qiáng)壯的類型語(yǔ)言,這就是說(shuō)在引用變量前必須首先聲明,要在執(zhí)行或異常處理部分使用變量,那么變量必須首先在聲明部分進(jìn)行聲明。
聲明變量的語(yǔ)法如下:
Variable_name [CONSTANT] databyte [NOT NULL][:=|DEFAULT expression] |
注意:可以在聲明變量的同時(shí)給變量強(qiáng)制性的加上NOT NULL約束條件,此時(shí)變量在初始化時(shí)必須賦值。
給變量賦值 給變量賦值有兩種方式:
. 直接給變量賦值
X:=200;
Y=Y+(X*20);
. 通過(guò)SQL SELECT INTO 或FETCH INTO給變量賦值
SELECT SUM(SALARY),SUM(SALARY*0.1)
INTO TOTAL_SALARY,TATAL_COMMISSION
FROM EMPLOYEE
WHERE DEPT=10;
常量 常量與變量相似,但常量的值在程序內(nèi)部不能改變,常量的值在定義時(shí)賦予,,他的聲明方式與變量相似,但必須包括關(guān)鍵字CONSTANT。常量和變量都可被定義為SQL和用戶定義的數(shù)據(jù)類型。
ZERO_VALUE CONSTANT NUMBER:=0; |
這個(gè)語(yǔ)句定了一個(gè)名叫ZERO_VALUE、數(shù)據(jù)類型是NUMBER、值為0的常量。
標(biāo)量(scalar)數(shù)據(jù)類型
標(biāo)量(scalar)數(shù)據(jù)類型沒(méi)有內(nèi)部組件,他們大致可分為以下四類:
. number
. character
. date/time
. boolean
表1顯示了數(shù)字?jǐn)?shù)據(jù)類型;表2顯示了字符數(shù)據(jù)類型;表3顯示了日期和布爾數(shù)據(jù)類型。
表1 Scalar Types:Numeric
Datatype | Range | Subtypes | description |
BINARY_INTEGER | -214748-2147483647 | NATURAL NATURAL NPOSITIVE POSITIVEN SIGNTYPE
| 用于存儲(chǔ)單字節(jié)整數(shù)。 要求存儲(chǔ)長(zhǎng)度低于NUMBER值。 用于限制范圍的子類型(SUBTYPE): NATURAL:用于非負(fù)數(shù) POSITIVE:只用于正數(shù) NATURALN:只用于非負(fù)數(shù)和非NULL值 POSITIVEN:只用于正數(shù),不能用于NULL值 SIGNTYPE:只有值:-1、0或1. |
NUMBER | 1.0E-130-9.99E125 | DEC DECIMAL DOUBLE PRECISION FLOAT INTEGERIC INT NUMERIC REAL SMALLINT | 存儲(chǔ)數(shù)字值,包括整數(shù)和浮點(diǎn)數(shù)。可以選擇精度和刻度方式,語(yǔ)法: number[([,])]。 缺省的精度是38,scale是0. |
PLS_INTEGER | -2147483647-2147483647 | ? | 與BINARY_INTEGER基本相同,但采用機(jī)器運(yùn)算時(shí),PLS_INTEGER提供更好的性能 。 |
表2 字符數(shù)據(jù)類型
datatype | rang | subtype | description |
CHAR | 最大長(zhǎng)度32767字節(jié) | CHARACTER | 存儲(chǔ)定長(zhǎng)字符串,如果長(zhǎng)度沒(méi)有確定,缺省是1 |
LONG | 最大長(zhǎng)度2147483647字節(jié) | ? | 存儲(chǔ)可變長(zhǎng)度字符串 |
RAW | 最大長(zhǎng)度32767字節(jié) | ? | 用于存儲(chǔ)二進(jìn)制數(shù)據(jù)和字節(jié)字符串,當(dāng)在兩個(gè)數(shù)據(jù)庫(kù)之間進(jìn)行傳遞時(shí),RAW數(shù)據(jù)不在字符集之間進(jìn)行轉(zhuǎn)換。 |
LONGRAW | 最大長(zhǎng)度2147483647 | ? | 與LONG數(shù)據(jù)類型相似,同樣他也不能在字符集之間進(jìn)行轉(zhuǎn)換。 |
ROWID | 18個(gè)字節(jié) | ? | 與數(shù)據(jù)庫(kù)ROWID偽列類型相同,能夠存儲(chǔ)一個(gè)行標(biāo)示符,可以將行標(biāo)示符看作數(shù)據(jù)庫(kù)中每一行的唯一鍵值。 |
VARCHAR2 | 最大長(zhǎng)度32767字節(jié) | STRINGVARCHAR | 與VARCHAR數(shù)據(jù)類型相似,存儲(chǔ)可變長(zhǎng)度的字符串。聲明方法與VARCHAR相同 |
表3 DATE和BOOLEAN
datatype | range | description |
BOOLEAN | TRUE/FALSE | 存儲(chǔ)邏輯值TRUE或FALSE,無(wú)參數(shù) |
DATE | 01/01/4712 BC | 存儲(chǔ)固定長(zhǎng)的日期和時(shí)間值,日期值中包含時(shí)間 |
LOB數(shù)據(jù)類型
LOB(大對(duì)象,Large object) 數(shù)據(jù)類型用于存儲(chǔ)類似圖像,聲音這樣的大型數(shù)據(jù)對(duì)象,LOB數(shù)據(jù)對(duì)象可以是二進(jìn)制數(shù)據(jù)也可以是字符數(shù)據(jù),其最大長(zhǎng)度不超過(guò)4G。LOB數(shù)據(jù)類型支持任意訪問(wèn)方式,LONG只支持順序訪問(wèn)方式。LOB存儲(chǔ)在一個(gè)單獨(dú)的位置上,同時(shí)一個(gè)"LOB定位符"(LOB locator)存儲(chǔ)在原始的表中,該定位符是一個(gè)指向?qū)嶋H數(shù)據(jù)的指針。在PL/SQL中操作LOB數(shù)據(jù)對(duì)象使用ORACLE提供的包DBMS_LOB.LOB數(shù)據(jù)類型可分為以下四類:
. BFILE
. BLOB
. CLOB
. NCLOB
操作符
與其他程序設(shè)計(jì)語(yǔ)言相同,PL/SQL有一系列操作符。操作符分為下面幾類:
. 算術(shù)操作符
. 關(guān)系操作符
. 比較操作符
. 邏輯操作符
算術(shù)操作符如表4所示
operator | operation |
+ | 加 |
- | 減 |
/ | 除 |
* | 乘 |
** | 乘方 |
關(guān)系操作符主要用于條件判斷語(yǔ)句或用于where子串中,關(guān)系操作符檢查條件和結(jié)果是否為true或false,表5是PL/SQL中的關(guān)系操作符
operator | operation |
< | 小于操作符 |
<= | 小于或等于操作符 |
> | 大于操作符 |
>= | 大于或等于操作符 |
= | 等于操作符 |
!= | 不等于操作符 |
<> | 不等于操作符 |
:= | 賦值操作符 |
表6 顯示的是比較操作符
operator | operation |
IS NULL | 如果操作數(shù)為NULL返回TRUE |
LIKE | 比較字符串值 |
BETWEEN | 驗(yàn)證值是否在范圍之內(nèi) |
IN | 驗(yàn)證操作數(shù)在設(shè)定的一系列值中 |
表7.8顯示的是邏輯操作符
operator | operation |
AND | 兩個(gè)條件都必須滿足 |
OR | 只要滿足兩個(gè)條件中的一個(gè) |
NOT | 取反 |
執(zhí)行部分 執(zhí)行部分包含了所有的語(yǔ)句和表達(dá)式,執(zhí)行部分以關(guān)鍵字BEGIN開(kāi)始,以關(guān)鍵字EXCEPTION結(jié)束,如果EXCEPTION不存在,那么將以關(guān)鍵字END結(jié)束。分號(hào)分隔每一條語(yǔ)句,使用賦值操作符:=或SELECT INTO或FETCH INTO給每個(gè)變量賦值,執(zhí)行部分的錯(cuò)誤將在異常處理部分解決,在執(zhí)行部分中可以使用另一個(gè)PL/SQL程序塊,這種程序塊被稱為嵌套塊
所有的SQL數(shù)據(jù)操作語(yǔ)句都可以用于執(zhí)行部分,PL/SQL塊不能再屏幕上顯示SELECT語(yǔ)句的輸出。SELECT語(yǔ)句必須包括一個(gè)INTO子串或者是游標(biāo)的一部分,執(zhí)行部分使用的變量和常量必須首先在聲明部分聲明,執(zhí)行部分必須至少包括一條可執(zhí)行語(yǔ)句,NULL是一條合法的可執(zhí)行語(yǔ)句,事物控制語(yǔ)句COMMIT和ROLLBACK可以在執(zhí)行部分使用,數(shù)據(jù)定義語(yǔ)言(Data Definition language)不能在執(zhí)行部分中使用,DDL語(yǔ)句與EXECUTE IMMEDIATE一起使用或者是DBMS_SQL調(diào)用。
執(zhí)行一個(gè)PL/SQL塊
SQL*PLUS中匿名的PL/SQL塊的執(zhí)行是在PL/SQL塊后輸入/來(lái)執(zhí)行,如下面的例子所示:
declare v_comm_percent constant number:=10; begin update emp set comm=sal*v_comm_percent where deptno=10; end SQL> / PL/SQL procedure successfully completed.
SQL> |
命名的程序與匿名程序的執(zhí)行不同,執(zhí)行命名的程序塊必須使用execute關(guān)鍵字:
create or replace procedure update_commission (v_dept in number,v_pervent in number default 10) is begin update emp set comm=sal*v_percent where deptno=v_dept; end
SQL>/
Procedure created
SQL>execute update_commission(10,15);
PL/SQL procedure successfully completed.
SQL> |
如果在另一個(gè)命名程序塊或匿名程序塊中執(zhí)行這個(gè)程序,那么就不需要EXECUTE關(guān)進(jìn)字。
declare v_dept number; begin select a.deptno into v_dept from emp a where job='PRESIDENT' update_commission(v_dept); end SQL>/ PL/SQL procedure successfully completed SQL> |