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

變量和常量

  變量存放在內(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>
            亚洲区一区二| 亚洲第一视频| 欧美亚洲在线观看| 亚洲伊人第一页| 国产精品对白刺激久久久| 91久久国产综合久久91精品网站| 国产精品乱人伦一区二区| 中文欧美字幕免费| 久久成人羞羞网站| 美女国内精品自产拍在线播放| 一二美女精品欧洲| 欧美成人一区二免费视频软件| 亚洲国产另类 国产精品国产免费| 亚洲欧美国产视频| 欧美大胆a视频| 小黄鸭视频精品导航| 亚洲麻豆视频| 精品成人一区二区三区四区| 欧美h视频在线| 欧美一级午夜免费电影| 国产精品日日摸夜夜添夜夜av| 日韩视频一区二区三区| 欧美在线影院在线视频| 亚洲深夜福利视频| 欧美视频一区在线| 亚洲一卡久久| 最新成人av在线| 欧美成人一区二区三区在线观看| 一本色道88久久加勒比精品 | 亚洲自拍另类| 国内成人精品一区| 国产麻豆9l精品三级站| 国产精品久久久久一区二区| 欧美精品乱码久久久久久按摩| 亚洲国内自拍| 亚洲国产精品va在线看黑人动漫| 久久在线播放| 欧美激情精品久久久久久蜜臀| 久久亚洲春色中文字幕久久久| 一个色综合av| 欧美一区日本一区韩国一区| 午夜久久电影网| 久久久亚洲精品一区二区三区| 亚洲欧美变态国产另类| 久久久成人精品| 亚洲精品一区二区三区在线观看 | 国产精品福利在线观看| 欧美精品一卡二卡| 久久aⅴ国产紧身牛仔裤| 欧美一进一出视频| 欧美激情第六页| 国产精品美女999| 在线免费高清一区二区三区| 99热这里只有成人精品国产| 亚洲女爱视频在线| 久久精品青青大伊人av| 欧美黄色aa电影| 久久蜜桃精品| 激情婷婷久久| 久久久久欧美| 久久精品官网| 欧美一区二区视频免费观看| 麻豆精品精华液| 久久久久在线观看| 国产日韩一区| 午夜精彩国产免费不卡不顿大片| 一区二区av在线| 麻豆精品视频在线| 久久精品一级爱片| 欧美日韩国产亚洲一区| 久久免费高清视频| 一区二区亚洲| 久久久www成人免费毛片麻豆| 亚洲婷婷综合久久一本伊一区| 欧美精品三级| 日韩一级成人av| 亚洲欧美日韩综合| 国产午夜久久| 老司机免费视频一区二区三区| 久久综合福利| 亚洲精品黄网在线观看| 欧美日韩精品不卡| 一本不卡影院| 美女网站久久| 亚洲调教视频在线观看| 国产欧美另类| 欧美xx69| 午夜在线成人av| 91久久久久久国产精品| 亚洲精品你懂的| 国产麻豆日韩| 欧美精品久久久久久久| 亚洲天堂av图片| 免费国产一区二区| 销魂美女一区二区三区视频在线| 黄色免费成人| 国产精品一区二区三区四区| 久久亚洲捆绑美女| 先锋资源久久| 亚洲专区在线| 亚洲视频在线一区| 日韩一级精品视频在线观看| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲蜜桃精久久久久久久| 国产亚洲人成a一在线v站| 欧美视频日韩视频| 欧美日韩另类字幕中文| 亚洲午夜精品17c| 久久女同精品一区二区| 亚洲欧美国产另类| 99精品视频免费观看| 在线免费观看日韩欧美| 国产女主播一区二区三区| 欧美日韩理论| 欧美日韩在线播放三区| 免费精品视频| 免费观看亚洲视频大全| 美国十次成人| 久久夜色精品国产亚洲aⅴ| 欧美国产日本在线| 欧美日韩一卡二卡| 欧美久久一级| 国产精品久久久久久久久婷婷| 国产精品免费视频xxxx| 精品成人乱色一区二区| 亚洲久久视频| 欧美影院成年免费版| 欧美va亚洲va香蕉在线| 亚洲精品在线免费| 欧美在线观看视频在线| 欧美精品一区三区| 国产亚洲aⅴaaaaaa毛片| 亚洲精品在线免费观看视频| 亚洲欧美视频| 一二三区精品| 欧美大尺度在线| 在线电影国产精品| 欧美亚洲在线观看| 99精品国产高清一区二区| 久久亚洲图片| 亚洲大片免费看| 久久乐国产精品| 欧美影院精品一区| 国产精品夜夜夜| 性欧美激情精品| 在线亚洲一区| 国产精品你懂的| 午夜亚洲伦理| 欧美一级播放| 国产亚洲欧美一级| 一区二区三区精品在线| 亚洲国产精品精华液网站| 蜜桃av综合| aa国产精品| 一区二区三区免费看| 国产精品久久亚洲7777| 亚洲一区图片| 羞羞答答国产精品www一本| 国产女人精品视频| 久久婷婷激情| 欧美国产丝袜视频| 亚洲综合精品| 久久免费黄色| 亚洲一区国产精品| 久久国产精品99国产| 亚洲人精品午夜| av72成人在线| 亚洲第一中文字幕在线观看| 亚洲日本欧美天堂| 国产综合一区二区| 日韩一区二区高清| 激情视频一区二区| 亚洲视频在线一区| av成人免费在线| 久久久天天操| 欧美影院成人| 国产精品欧美久久| 亚洲激情视频网| 亚洲福利电影| 午夜精品久久久久久久蜜桃app| 亚洲激情电影中文字幕| 久久国产成人| 久久久一区二区三区| 国产精品无人区| 亚洲午夜在线观看| 亚洲婷婷综合久久一本伊一区| 免费看亚洲片| 亚洲福利视频网站| 日韩午夜电影在线观看| 欧美高清日韩| 99re热这里只有精品免费视频| 亚洲国产三级在线| 女人香蕉久久**毛片精品| 欧美国产日韩一区| 亚洲美女视频| 国产精品白丝黑袜喷水久久久| 欧美韩日精品| 亚洲免费电影在线观看| 欧美成人69av| 日韩一级在线观看|