• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            變量和常量

              變量存放在內存中以獲得值,能被PL/SQL塊引用。你可以把變量想象成一個可儲藏東西的容器,容器內的東西是可以改變的。

              聲明變量

              變量一般都在PL/SQL塊的聲明部分聲明,PL/SQL是一種強壯的類型語言,這就是說在引用變量前必須首先聲明,要在執行或異常處理部分使用變量,那么變量必須首先在聲明部分進行聲明。

              聲明變量的語法如下:

            Variable_name [CONSTANT] databyte [NOT NULL][:=|DEFAULT expression]

              注意:可以在聲明變量的同時給變量強制性的加上NOT NULL約束條件,此時變量在初始化時必須賦值。

              給變量賦值

              給變量賦值有兩種方式:

              . 直接給變量賦值

               X:=200;
               Y=Y+(X*20);

              . 通過SQL SELECT INTO 或FETCH INTO給變量賦值

            SELECT SUM(SALARY),SUM(SALARY*0.1)
            INTO TOTAL_SALARY,TATAL_COMMISSION
            FROM EMPLOYEE
            WHERE DEPT=10;

              常量

              常量與變量相似,但常量的值在程序內部不能改變,常量的值在定義時賦予,,他的聲明方式與變量相似,但必須包括關鍵字CONSTANT。常量和變量都可被定義為SQL和用戶定義的數據類型。

            ZERO_VALUE CONSTANT NUMBER:=0;

              這個語句定了一個名叫ZERO_VALUE、數據類型是NUMBER、值為0的常量。

              標量(scalar)數據類型

              標量(scalar)數據類型沒有內部組件,他們大致可分為以下四類:

               . number
               . character
               . date/time
               . boolean

              表1顯示了數字數據類型;表2顯示了字符數據類型;表3顯示了日期和布爾數據類型。

              表1 Scalar Types:Numeric
            DatatypeRangeSubtypesdescription
            BINARY_INTEGER-214748-2147483647NATURAL
            NATURAL
            NPOSITIVE
            POSITIVEN
            SIGNTYPE
            用于存儲單字節整數。
            要求存儲長度低于NUMBER值。
            用于限制范圍的子類型(SUBTYPE):
             NATURAL:用于非負數
             POSITIVE:只用于正數
             NATURALN:只用于非負數和非NULL值
             POSITIVEN:只用于正數,不能用于NULL值
             SIGNTYPE:只有值:-1、0或1.
            NUMBER1.0E-130-9.99E125DEC
            DECIMAL
            DOUBLE
            PRECISION
            FLOAT
            INTEGERIC
            INT
            NUMERIC
            REAL
            SMALLINT
            存儲數字值,包括整數和浮點數。可以選擇精度和刻度方式,語法:
            number[([,])]。
            缺省的精度是38,scale是0.
            PLS_INTEGER-2147483647-2147483647?與BINARY_INTEGER基本相同,但采用機器運算時,PLS_INTEGER提供更好的性能 。

              表2 字符數據類型
            datatyperangsubtypedescription
            CHAR最大長度32767字節 CHARACTER存儲定長字符串,如果長度沒有確定,缺省是1
            LONG最大長度2147483647字節?存儲可變長度字符串
            RAW 最大長度32767字節?用于存儲二進制數據和字節字符串,當在兩個數據庫之間進行傳遞時,RAW數據不在字符集之間進行轉換。
            LONGRAW最大長度2147483647?與LONG數據類型相似,同樣他也不能在字符集之間進行轉換。
            ROWID18個字節?與數據庫ROWID偽列類型相同,能夠存儲一個行標示符,可以將行標示符看作數據庫中每一行的唯一鍵值。
            VARCHAR2最大長度32767字節STRINGVARCHAR與VARCHAR數據類型相似,存儲可變長度的字符串。聲明方法與VARCHAR相同

              表3 DATE和BOOLEAN
            datatyperange description
            BOOLEANTRUE/FALSE存儲邏輯值TRUE或FALSE,無參數
            DATE01/01/4712 BC 存儲固定長的日期和時間值,日期值中包含時間

              LOB數據類型

              LOB(大對象,Large object) 數據類型用于存儲類似圖像,聲音這樣的大型數據對象,LOB數據對象可以是二進制數據也可以是字符數據,其最大長度不超過4G。LOB數據類型支持任意訪問方式,LONG只支持順序訪問方式。LOB存儲在一個單獨的位置上,同時一個"LOB定位符"(LOB locator)存儲在原始的表中,該定位符是一個指向實際數據的指針。在PL/SQL中操作LOB數據對象使用ORACLE提供的包DBMS_LOB.LOB數據類型可分為以下四類:

              . BFILE
              . BLOB
              . CLOB
              . NCLOB

              操作符

              與其他程序設計語言相同,PL/SQL有一系列操作符。操作符分為下面幾類:

              . 算術操作符

              . 關系操作符

              . 比較操作符

              . 邏輯操作符

              算術操作符如表4所示

            operatoroperation
            +
            -
            /
            *
            **乘方

              關系操作符主要用于條件判斷語句或用于where子串中,關系操作符檢查條件和結果是否為true或false,表5是PL/SQL中的關系操作符

            operatoroperation
            < 小于操作符
            <= 小于或等于操作符
            > 大于操作符
            >=大于或等于操作符
            = 等于操作符
            != 不等于操作符
            <> 不等于操作符
            := 賦值操作符

              表6 顯示的是比較操作符
            operator operation
            IS NULL如果操作數為NULL返回TRUE
            LIKE比較字符串值
            BETWEEN驗證值是否在范圍之內
            IN驗證操作數在設定的一系列值中

              表7.8顯示的是邏輯操作符
            operatoroperation
            AND 兩個條件都必須滿足
            OR只要滿足兩個條件中的一個
            NOT取反

              執行部分

              執行部分包含了所有的語句和表達式,執行部分以關鍵字BEGIN開始,以關鍵字EXCEPTION結束,如果EXCEPTION不存在,那么將以關鍵字END結束。分號分隔每一條語句,使用賦值操作符:=或SELECT INTO或FETCH INTO給每個變量賦值,執行部分的錯誤將在異常處理部分解決,在執行部分中可以使用另一個PL/SQL程序塊,這種程序塊被稱為嵌套塊

              所有的SQL數據操作語句都可以用于執行部分,PL/SQL塊不能再屏幕上顯示SELECT語句的輸出。SELECT語句必須包括一個INTO子串或者是游標的一部分,執行部分使用的變量和常量必須首先在聲明部分聲明,執行部分必須至少包括一條可執行語句,NULL是一條合法的可執行語句,事物控制語句COMMIT和ROLLBACK可以在執行部分使用,數據定義語言(Data Definition language)不能在執行部分中使用,DDL語句與EXECUTE IMMEDIATE一起使用或者是DBMS_SQL調用。

              執行一個PL/SQL塊

              SQL*PLUS中匿名的PL/SQL塊的執行是在PL/SQL塊后輸入/來執行,如下面的例子所示:

            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>

              命名的程序與匿名程序的執行不同,執行命名的程序塊必須使用execute關鍵字:

            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>


              如果在另一個命名程序塊或匿名程序塊中執行這個程序,那么就不需要EXECUTE關進字。

            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>
            Posted on 2006-09-26 16:51 艾凡赫 閱讀(495) 評論(0)  編輯 收藏 引用 所屬分類: ORACLE數據庫
            久久久免费精品re6| 2021国产精品久久精品| 99国产欧美久久久精品蜜芽| 久久丫精品国产亚洲av| 国产精品久久自在自线观看| 日本三级久久网| 亚洲精品视频久久久| 99re久久精品国产首页2020| 久久久91精品国产一区二区三区| 久久久久亚洲精品中文字幕| 99蜜桃臀久久久欧美精品网站| 精品久久久久久中文字幕| 人妻少妇精品久久| 精品一区二区久久| 亚洲午夜久久久久妓女影院| 亚洲一区二区三区日本久久九| 亚洲国产精品无码久久九九 | 久久久久无码精品国产不卡| 99久久国产综合精品五月天喷水 | 77777亚洲午夜久久多喷| 99久久久久| 久久久久久九九99精品| 97香蕉久久夜色精品国产| 九九久久精品无码专区| 久久99精品久久久久久久久久| 伊色综合久久之综合久久| 久久久久国产精品三级网| 国内精品久久久久国产盗摄| 久久99国产精品99久久| 国产韩国精品一区二区三区久久| 日日噜噜夜夜狠狠久久丁香五月| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久福利片| 91精品国产综合久久四虎久久无码一级 | 无码久久精品国产亚洲Av影片| 伊人久久成人成综合网222| 久久性精品| 97香蕉久久夜色精品国产| 亚洲中文字幕久久精品无码喷水 | 亚洲国产成人精品91久久久| 久久精品国产99国产精品|