青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

變量和常量

  變量存放在內(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
DatatypeRangeSubtypesdescription
BINARY_INTEGER-214748-2147483647NATURAL
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.
NUMBER1.0E-130-9.99E125DEC
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ù)類型
datatyperangsubtypedescription
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)換。
ROWID18個(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
datatyperange description
BOOLEANTRUE/FALSE存儲(chǔ)邏輯值TRUE或FALSE,無(wú)參數(shù)
DATE01/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所示

operatoroperation
+
-
/
*
**乘方

  關(guān)系操作符主要用于條件判斷語(yǔ)句或用于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 兩個(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>
Posted on 2006-09-26 16:51 艾凡赫 閱讀(507) 評(píng)論(0)  編輯 收藏 引用 所屬分類: ORACLE數(shù)據(jù)庫(kù)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国产手机看片| 亚洲乱码国产乱码精品精98午夜| 亚洲精品女人| 亚洲国产裸拍裸体视频在线观看乱了中文 | 伊大人香蕉综合8在线视| 久久精品视频99| 久久久在线视频| 亚洲日产国产精品| 亚洲中字在线| 亚洲第一福利视频| 一区二区av在线| 欧美日韩性生活视频| 一卡二卡3卡四卡高清精品视频| 欧美激情一二区| 欧美韩日视频| 久久aⅴ乱码一区二区三区| 亚洲一区免费网站| 亚洲第一久久影院| 久久综合狠狠| 欧美精品在线免费| 久久精品国产2020观看福利| 欧美国产日韩二区| 免费成人在线观看视频| 欧美体内she精视频在线观看| 欧美一区亚洲一区| 欧美国产日韩精品| 国产精品激情偷乱一区二区∴| 亚洲欧美另类综合偷拍| 久久久久国产一区二区| 一区二区在线不卡| 一本久久综合亚洲鲁鲁五月天| 亚洲国产三级网| 亚洲欧美文学| 亚洲欧美日韩天堂| 国产精品久久久久久久久果冻传媒| 久久全球大尺度高清视频| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 欧美大尺度在线| 亚洲区一区二区三区| 欧美91精品| 亚洲午夜国产一区99re久久| 亚洲欧美日韩第一区| 狠狠色综合日日| 欧美日韩天堂| 久久婷婷国产综合尤物精品| 欧美大尺度在线观看| 在线综合+亚洲+欧美中文字幕| 国产乱肥老妇国产一区二| 午夜精品久久久久久久99热浪潮| 久久国产一区| 日韩一级在线| 最新热久久免费视频| 欧美三级电影一区| 午夜国产欧美理论在线播放 | 亚洲经典在线| 久久精品最新地址| 一区二区三区国产精华| 黄色亚洲网站| 欧美日韩成人在线观看| 午夜精品成人在线视频| 亚洲高清在线观看| 国产精品永久免费| 欧美色图五月天| 欧美日韩免费| 欧美电影资源| 久久婷婷国产综合精品青草| 在线视频一区观看| 亚洲美女少妇无套啪啪呻吟| 久久一二三四| 欧美在线资源| 久久精品综合网| 久久久国产精品亚洲一区| 亚洲综合清纯丝袜自拍| 亚洲毛片在线观看| 亚洲精品四区| 一区二区三区欧美在线观看| 亚洲激情专区| 日韩亚洲精品视频| 精品91久久久久| 国产亚洲精品bv在线观看| 免费人成精品欧美精品| 久久久天天操| 99ri日韩精品视频| 中国女人久久久| 亚洲欧美激情四射在线日| 一区二区欧美在线观看| 欧美在线视频日韩| 欧美韩国一区| 国产日韩av高清| 亚洲精品影视| 久久精品伊人| 亚洲乱码精品一二三四区日韩在线 | 午夜精品久久久久久久男人的天堂| 午夜精品久久久久| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产日韩精品在线| 精品999网站| 欧美在线视频在线播放完整版免费观看 | 久久久久久亚洲综合影院红桃| 欧美在线精品免播放器视频| 欧美jizz19hd性欧美| 最近中文字幕日韩精品| 久久国产一区二区| 国产日韩在线不卡| 亚洲天堂av在线免费| 亚洲欧洲一区二区在线播放| 久久爱另类一区二区小说| 欧美性一区二区| 亚洲女人天堂成人av在线| 亚洲日本va午夜在线电影| 另类国产ts人妖高潮视频| 国产精品免费看久久久香蕉| 日韩视频专区| 亚洲高清不卡av| 久久久噜噜噜久久狠狠50岁| 1024国产精品| 欧美大片在线观看| 久久综合久久综合久久综合| 国产人成精品一区二区三| 欧美在线网址| 久久gogo国模裸体人体| 国产欧美va欧美va香蕉在| 免费日韩av| 国产精品一区毛片| 欧美成人免费观看| 免费不卡在线观看| 亚洲精选国产| 亚洲伦理自拍| 亚洲欧美电影院| 亚洲国产欧美精品| 午夜精品福利一区二区蜜股av| 狠狠色狠狠色综合人人| 亚洲激情视频在线| 国产精品mm| 久久亚洲精品网站| 欧美日韩精品系列| 亚洲高清视频中文字幕| 欧美午夜精品久久久久久人妖| 久久激情一区| 欧美视频在线观看免费网址| 免播放器亚洲一区| 欧美乱妇高清无乱码| 另类春色校园亚洲| 国产中文一区二区| 亚洲另类黄色| 国产日韩欧美精品在线| 亚洲国产视频a| 亚洲国产精品成人| 欧美激情精品久久久久久久变态| 久久成人18免费观看| 欧美日韩一区二区三区| 久久一区国产| 日韩视频在线你懂得| 久久视频在线视频| 欧美高潮视频| 亚洲一区在线播放| 国产亚洲制服色| 另类尿喷潮videofree| 亚洲三级视频| 亚洲欧美日韩一区二区三区在线观看| 欧美精品久久久久久久| 一二三区精品| 蜜桃久久av| 亚洲一区在线看| 国产日韩在线视频| 久热爱精品视频线路一| 一区二区三区国产精品| 久久一区二区三区超碰国产精品| 在线精品在线| 国产精品久久久一区二区| 欧美一区二区大片| 亚洲国产毛片完整版| 亚洲一区二区精品在线观看| 国产欧美精品va在线观看| 卡通动漫国产精品| 亚洲综合社区| 亚洲盗摄视频| 国外成人免费视频| 国产精品美女| 国产精品二区影院| 免费在线成人| 久久天堂av综合合色| 米奇777超碰欧美日韩亚洲| 一区二区av| 亚洲乱码精品一二三四区日韩在线 | 日韩一级免费| 国产一区在线免费观看| 国产精品久久久久999| 欧美精品色综合| 欧美激情综合网| 欧美日本不卡视频| 欧美三级视频在线播放| 欧美精品18| 国产精品久久久久久久app| 欧美日韩一区二区三区在线看| 欧美成人亚洲| 国产精品二区三区四区| 国产精品乱码人人做人人爱| 欧美午夜国产| 狠狠综合久久|