PLSQL中的變量使用

在編寫pl/sql程序時,可以定義變量和常量;在pl/sql程序中包括有:
(1). 標量類型(scalar)
(2). 複合類型(composite)
(3). 參照類型(reference)
(4). lob(large object)
1.  標量(scalar)——常用類型
     在編寫pl/sql塊時,如果要使用變量,需在定義部分定義變量。pl/sql中定義變量和常量的語法如下:
     identifier [constant] datatype [not null] [:=| default expr]
     identifier : 名稱
     constant :指定常量。需要指定它的初始值,且其值是不能改變的
     datatype :數據類型
     not null :指定變量值不能爲null
     := 給變量或是常量指定初始值
     default 用於指定初始值
     expr :指定初始值的pl/sql表達式,可以是文本值、其它變量、函數等。
標量定義的案例
(1). 定義一個變長字符串
      v_ename varchar2(10);
(2). 定義一個小數,範圍 -9999.99~9999.99
      v_sal number(6,2);
(3). 定義一個小數並給一個初始值爲5.4 :=是pl/sql的賦值號
      v_sal2 number(6,2):=5.4;
(4). 定義一個日期類型的數據
      v_hiredate date;
(5). 定義一個布爾變量,不能爲空,初始值爲false
      v_valid boolean not null default false;
2.  標量(scalar)——使用標量
     在定義好變量後,就可以使用這些變量。這裏需要說明的是pl/sql塊爲變量賦值不同於其它的編程語言,需要在等號前面加冒號(:=)
下面以輸入員工號,顯示僱員姓名、工資、個人所得稅(稅率爲0.03)爲例。說明變量的使用,看看如何編寫。

    

標量(scalar)——使用%type類型
對於上面的pl/sql塊有一個問題:
就是如果員工的姓名超過了5個字符的話,就會有錯誤,爲了降低pl/sql程序的維護工作量,可以使用%type屬性定義變量,這樣它會按照數據庫列來確定你定義的變量的類型和長度。
我們看看這個怎麼使用:
標識符名 表名.列名%type;
比如上例的v_ename,這樣定義:v_ename emp.ename%type;
3.  複合變量(composite)——介紹
     用於存放多個值的變量。主要包括這幾種:
     pl/sql記錄
     pl/sql表
     嵌套表
     varray
(1). 複合類型——pl/sql記錄
      類似於高級語言中的結構體,需要注意的是,當引用pl/sql記錄成員時,必須要加記錄變量作爲前綴(記錄變量.記錄成員)如下:

 (2). 複合類型-pl/sql表
      相當於高級語言中的數組,但是需要注意的是在高級語言中數組的下標不能爲負數,而pl/sql是可以爲負數的,並且表元素的下標沒有限制。實例如下:
 
    說明:
    sp_table_type 是pl/sql表類型
    emp.ename%type 指定了表的元素的類型和長度
    sp_table 爲pl/sql表變量
    sp_table(0) 則表示下標爲0的元素
    注意:如果把select ename into sp_table(-1) from emp where empno = 7788; 變成select ename into sp_table(-1) from emp;則運行時會出現錯誤,錯誤如下:
ORA-01422:實際返回的行數超出請求的行數
解決方法是:使用參照變量(這裏不講)
(3). 複合變量——嵌套表(nested table)
(4). 複合變量——變長數組(varray)
(5). 參照變量——介紹
      參照變量是指用於存放數值指針的變量。通過使用參照變量,可以使得應用程序共享相同對象,從而降低佔用的空間。在編寫pl/sql程序時,可以使用遊標變量(ref cursor)和對象類型變量(ref obj_type)兩種參照變量類型。
(6). 參照變量——ref cursor遊標變量
      使用遊標時,當定義遊標時不需要指定相應的select語句,但是當使用遊標時(open時)需要指定select語句,這樣一個遊標就與一個select語句結合了。實例如下:
1.請使用pl/sql編寫一個塊,可以輸入部門號,並顯示該部門所有員工姓名和他的工資。
2.在1的基礎上,如果某個員工的工資低於200元,就添加100元。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章