欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle PL/SQL入門案例實(shí)踐

 更新時間:2007年03月07日 00:00:00   作者:  
正在看的ORACLE教程是:Oracle PL/SQL入門案例實(shí)踐?!∏懊嬉呀?jīng)了解了關(guān)于PL/SQL編程的基礎(chǔ),本文將結(jié)合一個案例來加深對這些知識點(diǎn)的理解。

  一. 案例介紹

  某數(shù)據(jù)庫有兩張表,是關(guān)于某公司員工資料、薪水和部門信息的,它們分別是emp表和dept表,兩張表的結(jié)構(gòu)如下:


  要求如下:

  1、按照上表結(jié)構(gòu)建立相應(yīng)的表,并每張表寫入5組合法數(shù)據(jù)。

  2、操縱相關(guān)表,使得“技術(shù)部”的員工的薪水上漲20%。

  3、建立日志,追蹤薪水變動情況。

  4、建立測試包。

  二. 案例的分析與實(shí)現(xiàn)

  從前面案例的介紹不難看出,要求1考察點(diǎn)為基本SQL語句;要求2主要考察復(fù)合查詢;要求3是考察觸發(fā)器的應(yīng)用;要求4的考察面相對多一些,不僅考察了包的創(chuàng)建,而且也考察了在PL/SQL中的測試方法。了解了這些考察的知識點(diǎn),就可以一一去解決。

  要求1:

  首先根據(jù)前面表的結(jié)構(gòu)可以創(chuàng)建兩張表:

  ——創(chuàng)建員工表


  ——部門表


  建立了表之后就可以往表里面寫數(shù)據(jù)了,這里把添加表記錄的代碼寫入到相應(yīng)的存儲過程。


  要求2:

  給指定部門的員工加薪,這實(shí)際上是一個復(fù)合查詢,首先需要把所有該部門的員工塞選出來,然后對這些員工的薪水進(jìn)行相應(yīng)的改動。依照這一思路,代碼如下:

 ?。ㄐ枰⒁獾氖牵簩⒁有降牟块T作為參數(shù),這樣的存儲過程更有靈活性。)


  要求3:

  建立日志對薪水的變動情況形成一個追蹤,也就是說,如果對某個職員的薪水進(jìn)行變更就應(yīng)該將其相應(yīng)的變更記錄全部記下來。如果對emp表的salary字段創(chuàng)建一個觸發(fā)器,來監(jiān)視對salary的更改,把每次更改進(jìn)行記錄,這樣就達(dá)到了要求3的目的了。


  要求4:

  與其他語言(c/c++等)相比,PL/SQL的測試有其不同之處,歸納下來有三種方法:

  1、使用DBMS_OUTPUT包的PUT_LINE方法來顯示中間變量,以此來觀察程序是否存在邏輯錯誤。

  2、插入測試表的方法。即創(chuàng)建一個臨時的中間表,然后把所有涉及到的中間變量的結(jié)果都作為記錄插入到中間表中,這樣可以查詢表中的結(jié)果來觀察程序的執(zhí)行情況。

  3、使用異常處理手段,對可疑的程序段使用begin … end ,然后可以在exception里進(jìn)行異常捕獲處理。

  這里準(zhǔn)備使用第二種方法來建立一個測試包,PL/SQL里包的概念類似于面向?qū)ο罄锏念惖母拍睿鼘⒁唤M操作和屬性封裝在一起,不僅增強(qiáng)了程序的模塊化,而且由于封裝了更多的操作和屬性而提高了執(zhí)行效能。建立一個PL/SQL需要兩個步驟:首先要建立包頭,類似于建立一個類的頭文件,里面主要對包中的過程,函數(shù)和變量的聲明;第二部分主要是包體部分,實(shí)現(xiàn)前面聲明的過程和函數(shù),另外還需要對包進(jìn)行初始化等工作。

  根據(jù)這一思路,建立測試包如下:


  三.小結(jié)

  綜合前面對4個問題的解答,基本把PL/SQL的主要部分融會進(jìn)來了,雖然很多地方只是涉及到比較粗淺的層次,但是有了這一基礎(chǔ),深入下去也是不難的。

  總之,PL/SQL編程與其他語言編程有一定的區(qū)別,讀者只有把握好其特點(diǎn)才能更好的掌握數(shù)據(jù)庫開發(fā)的方面知識。

相關(guān)文章

最新評論