• <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>
            變量和常量

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

              聲明變量

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

              聲明變量的語法如下:

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

              注意:可以在聲明變量的同時給變量強(qiáng)制性的加上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;

              常量

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

            ZERO_VALUE CONSTANT NUMBER:=0;

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

              標(biāo)量(scalar)數(shù)據(jù)類型

              標(biāo)量(scalar)數(shù)據(jù)類型沒有內(nèi)部組件,他們大致可分為以下四類:

               . number
               . character
               . date/time
               . boolean

              表1顯示了數(shù)字?jǐn)?shù)據(jù)類型;表2顯示了字符數(shù)據(jù)類型;表3顯示了日期和布爾數(shù)據(jù)類型。

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

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

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

              LOB數(shù)據(jù)類型

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

              . BFILE
              . BLOB
              . CLOB
              . NCLOB

              操作符

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

              . 算術(shù)操作符

              . 關(guān)系操作符

              . 比較操作符

              . 邏輯操作符

              算術(shù)操作符如表4所示

            operatoroperation
            +
            -
            /
            *
            **乘方

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

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

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

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

              執(zhí)行部分

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

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

              執(zhí)行一個PL/SQL塊

              SQL*PLUS中匿名的PL/SQL塊的執(zhí)行是在PL/SQL塊后輸入/來執(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>


              如果在另一個命名程序塊或匿名程序塊中執(zhí)行這個程序,那么就不需要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>
            Posted on 2006-09-26 16:51 艾凡赫 閱讀(499) 評論(0)  編輯 收藏 引用 所屬分類: ORACLE數(shù)據(jù)庫
            国产精品久久毛片完整版| 久久久久亚洲AV无码去区首| 看久久久久久a级毛片| 久久久噜噜噜www成人网| 日本福利片国产午夜久久| 思思久久好好热精品国产| 久久精品一本到99热免费| 久久99精品国产麻豆婷婷| 少妇精品久久久一区二区三区| 精品久久久久久综合日本| 欧美粉嫩小泬久久久久久久 | 波多野结衣AV无码久久一区| 麻豆AV一区二区三区久久| 久久久国产一区二区三区| 2022年国产精品久久久久| 一级a性色生活片久久无| 久久亚洲欧美日本精品| 亚洲国产精品无码久久久不卡| 亚洲国产精品久久久久婷婷老年 | 97久久超碰国产精品旧版| 日韩AV毛片精品久久久| 久久99久久99小草精品免视看| 久久人人青草97香蕉| yellow中文字幕久久网| 成人久久精品一区二区三区| 亚洲国产精品无码久久久蜜芽| 亚洲人成网站999久久久综合 | 国产精品成人无码久久久久久| 97精品依人久久久大香线蕉97| 久久久久人妻精品一区三寸蜜桃| 国产精品久久久久影院色| 国产精品对白刺激久久久| 伊人久久大香线蕉亚洲五月天 | 老司机午夜网站国内精品久久久久久久久 | 色综合久久天天综线观看| 久久综合给合久久狠狠狠97色| 国产—久久香蕉国产线看观看| 亚洲精品乱码久久久久久蜜桃| 久久亚洲日韩看片无码| 一日本道伊人久久综合影| 91亚洲国产成人久久精品网址|