oracle plsql從入門(mén)到精通配套資源所有課件第6章_第1頁(yè)
oracle plsql從入門(mén)到精通配套資源所有課件第6章_第2頁(yè)
oracle plsql從入門(mén)到精通配套資源所有課件第6章_第3頁(yè)
oracle plsql從入門(mén)到精通配套資源所有課件第6章_第4頁(yè)
oracle plsql從入門(mén)到精通配套資源所有課件第6章_第5頁(yè)
已閱讀5頁(yè),還剩10頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第6章PL/SQL與Oracle服務(wù)器之間的交互2023/9/291————真理就在面前、真理就在手下————2023/9/29————真理就在面前、真理就在手下————2目標(biāo)在PL/SQL中包含SELECT語(yǔ)句

在PL/SQL中包含DML語(yǔ)句

在PL/SQL中控制事物(transactions)確定SQL數(shù)據(jù)維護(hù)語(yǔ)言(DML)語(yǔ)句的輸出2023/9/29————真理就在面前、真理就在手下————3PL/SQL中的SQL語(yǔ)句通過(guò)使用SELECT

命令從數(shù)據(jù)庫(kù)中提取數(shù)據(jù)行通過(guò)使用DML命令對(duì)數(shù)據(jù)庫(kù)中的數(shù)據(jù)行進(jìn)行修改利用COMMIT、ROLLBACK、或SAVEPOINT命令來(lái)控制事物(交易)2023/9/29————真理就在面前、真理就在手下————4PL/SQL中的SELECT語(yǔ)句通過(guò)使用SELECT

語(yǔ)句從數(shù)據(jù)庫(kù)中提取數(shù)據(jù)語(yǔ)法:SELECTselect_listINTO {variable_name[,variable_name]... |record_name}

FROM table[WHERE condition];2023/9/29————真理就在面前、真理就在手下————5PL/SQL中的SELECT語(yǔ)句需要使用

INTO

子句查詢必須返回而且只能返回一行例:DECLAREv_deptno NUMBER(8);v_loc NUMBER(8);BEGINSELECT deptno,locINTO v_deptno,v_locFROM dept_plWHERE dname=‘保衛(wèi)部';

...END;/2023/9/29————真理就在面前、真理就在手下————6從數(shù)據(jù)庫(kù)中提取數(shù)據(jù)提取特定雇員的雇傭日期和工資例:DECLAREv_hire_dateemp_pl.hiredate%TYPE;v_salemp_pl.sal%TYPE;BEGINSELECThiredate,salINTOv_hire_date,v_salFROMemp_plWHEREempno=7788;...END;/2023/9/29————真理就在面前、真理就在手下————7從數(shù)據(jù)庫(kù)中提取數(shù)據(jù)返回特定部門(mén)中所有員工的工資總合。例:SETserveroutputONSETverifyOFFDECLAREv_sum_salemp.sal%TYPE;v_deptno NUMBERNOTNULL:=&p_department_id;BEGINSELECT SUM(sal)--groupfunctionINTO v_sum_salFROM empWHERE deptno=v_deptno;DBMS_OUTPUT.PUT_LINE(v_deptno||'號(hào)部門(mén)的工資總和為:'||v_sum_sal);END;2023/9/29————真理就在面前、真理就在手下————8命名慣例DECLAREenameemp.ename%TYPE;hiredateemp.hiredate%TYPE;salemp.sal%TYPE;v_empnoemp.empno%TYPE:=7788;BEGINSELECT ename,hiredate,salINTO ename,hiredate,salFROM empWHERE empno=v_empno;END;/2023/9/29————真理就在面前、真理就在手下————9INSERTUPDATEDELETE使用PL/SQL來(lái)維護(hù)數(shù)據(jù)通過(guò)使用DML命令對(duì)數(shù)據(jù)庫(kù)的表進(jìn)行修改:INSERTUPDATEDELETEMERGEMERGE2023/9/29————真理就在面前、真理就在手下————10插入數(shù)據(jù)向部門(mén)(dept)表中添加一新的部門(mén)信息例:BEGININSERTINTOdept(deptno,dname,loc)VALUES(deptid_sequence.NEXTVAL,'公關(guān)部', '公主墳區(qū)');END;/2023/9/29————真理就在面前、真理就在手下————11修改數(shù)據(jù)增加所有文員員工(CLERK)的工資例:SETverifyOFFDECLARE v_sal_increaseemp.sal%TYPE:=&p_salary_increase;BEGINUPDATE empSET sal=sal+v_sal_increaseWHERE job='CLERK';END;/2023/9/29————真理就在面前、真理就在手下————12刪除數(shù)據(jù)從EMP_PL

表中刪除特定職務(wù)并且工資高于某一標(biāo)準(zhǔn)的全部員工的數(shù)據(jù)例:SETverifyOFFDECLAREv_jobemp_pl.job%TYPE:='&p_job';v_salemp_pl.sal%TYPE:=&p_salary;BEGIN DELETEFROMemp_plWHEREjob=v_jobAND sal>v_sal;END;/2023/9/29————真理就在面前、真理就在手下————13合并行根據(jù)匹配條件利用EMP表向COPY_EMP表中插入數(shù)據(jù)行或修改COPY_EMP表中的數(shù)據(jù)行BEGINMERGEINTOcopy_empcUSINGempeON(c.empno=e.empno)WHENMATCHEDTHENUPDATESETc.empno=e.empno,c.ename=e.ename,c.job=e.job,c.mgr=e.mgr,c.hiredate=e.hiredate,……WHENNOTMATCHEDTHENINSERTVALUES(e.empno,e.ename,e.job,e.mgr,e.hiredate,e.sal,m,e.deptno);END;2023/9/29————真理就在面前、真理就在手下————14命名慣例使用命名慣例來(lái)避免在WHERE子句中的二義性數(shù)據(jù)庫(kù)的列和標(biāo)識(shí)符應(yīng)該使用不同的名因?yàn)镻L/SQL首先檢查數(shù)據(jù)庫(kù)的表中的列,所以可能產(chǎn)生語(yǔ)法錯(cuò)誤本地變量和形式參數(shù)名優(yōu)先于數(shù)據(jù)庫(kù)的表名列名優(yōu)先于本地變量

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論