《SQL數(shù)據(jù)庫》PPT課件.ppt

上傳人:xin****828 文檔編號:15729836 上傳時間:2020-09-01 格式:PPT 頁數(shù):26 大小:273.36KB
收藏 版權(quán)申訴 舉報 下載
《SQL數(shù)據(jù)庫》PPT課件.ppt_第1頁
第1頁 / 共26頁
《SQL數(shù)據(jù)庫》PPT課件.ppt_第2頁
第2頁 / 共26頁
《SQL數(shù)據(jù)庫》PPT課件.ppt_第3頁
第3頁 / 共26頁

下載文檔到電腦,查找使用更方便

9.9 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《《SQL數(shù)據(jù)庫》PPT課件.ppt》由會員分享,可在線閱讀,更多相關(guān)《《SQL數(shù)據(jù)庫》PPT課件.ppt(26頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、在大型數(shù)據(jù)庫系統(tǒng)中,存儲過程和觸發(fā)器具有很重要的作用。無論是存儲過程還是觸發(fā)器,都是SQL語句和流程控制語句的集合。就本質(zhì)而言,觸發(fā)器也是一種存儲過程,它在特定語言事件發(fā)生時自動執(zhí)行。存儲過程在運算時生成執(zhí)行代碼,所以,以后對其再運行時其執(zhí)行效率很高。SQL Server 2005不僅提供了用戶自定義存儲過程的功能,而且也提供了許多可作為工具使用的系統(tǒng)存儲過程。 本章主要介紹存儲過程和觸發(fā)器的概念和分類以及它們的使用方法。,,第10章 存儲過程和觸發(fā)器,10.1 存儲過程 10.2 觸發(fā)器,,第10章 存儲過程和觸發(fā)器,10.1.1 存儲過程概述 存儲過程(Stored Procedure)是

2、一組完成特定功能的SQL語句集,經(jīng)編譯后存儲在數(shù)據(jù)庫中。用戶通過指定存儲過程的名字并給出參數(shù)(如果該存儲過程帶有參數(shù))來執(zhí)行存儲過程。 利用SQL Server創(chuàng)建一個應(yīng)用程序時,SQL是主要的編程語言。使用SQL進行編程,有兩種方法。其一是,在本地存儲SQL程序,并創(chuàng)建應(yīng)用程序向SQL Server發(fā)送命令來對結(jié)果進行處理。其二是,可以把部分用SQL編寫的程序作為存儲過程存儲在SQL Server中,然后創(chuàng)建應(yīng)用程序來調(diào)用存儲過程,對數(shù)據(jù)結(jié)果進行處理。,,10.1 存儲過程,存儲過程具有以下優(yōu)點: 1. 存儲過程允許標(biāo)準(zhǔn)組件式編程 2. 存儲過程能夠?qū)崿F(xiàn)較快的執(zhí)行速度 3. 存儲過程能夠減少

3、網(wǎng)絡(luò)流量 4. 存儲過程可被作為一種安全機制來充分利用,,10.1 存儲過程,10.1.2 存儲過程的類型 在SQL Server 2005中有多種可用的存儲過程。在SQL Server 2005中存儲過程分為三類:系統(tǒng)提供的存儲過程、用戶自定義存儲過程和擴展存儲過程。 1. 系統(tǒng)存儲過程 SQL Server 2005中的許多管理活動都是通過一種特殊的存儲過程執(zhí)行的,這種存儲過程被稱為系統(tǒng)存儲過程。系統(tǒng)過程主要存儲在master數(shù)據(jù)庫中并以sp_為前綴,并且系統(tǒng)存儲過程主要是從系統(tǒng)表中獲取信息,從而為數(shù)據(jù)庫系統(tǒng)管理員管理SQL Server提供支持。通過系統(tǒng)存儲過程,SQL Server中的

4、許多管理性或信息性的活動(如獲取數(shù)據(jù)庫和數(shù)據(jù)庫對象的信息)都可以被順利有效地完成。,,10.1 存儲過程,2. 用戶自定義的存儲過程 用戶自定義存儲過程是由用戶創(chuàng)建并能完成某一特定功能(如查詢用戶所需數(shù)據(jù)信息)的存儲過程,是封裝了可重用代碼的SQL語句模塊。存儲過程可以接受輸入?yún)?shù)、向客戶端返回表格或標(biāo)量結(jié)果和消息、調(diào)用數(shù)據(jù)定義語言(DDL)和數(shù)據(jù)操作語言(DML)語句,以及返回輸出參數(shù)。在SQL Server中,用戶自定義的存儲過程有兩種類型:T-SQL存儲過程或CLR存儲過程。本書所提到的用戶定義的存儲過程主要指T-SQL存儲過程。 3. 擴展存儲過程 擴展存儲過程允許使用高級編程語言(例

5、如C)創(chuàng)建應(yīng)用程序的外部例程,從而使得SQL Server的實例可以動態(tài)加載和運行DLL。擴展存儲過程直接在SQL Server實例的地址空間中運行。,,10.1 存儲過程,10.1.3 存儲過程的設(shè)計規(guī)則 使用SQL語句CREATE PROCEDURE可以創(chuàng)建存儲過程。其語法格式如下: CREATE PROC | PROCEDURE schema_name. procedure_name ; number parameter type_schema_name. data_type VARYING = default OUT PUT ,...n WITH ,...n FO

6、R REPLICATION AS ; ...n | ;,,10.1 存儲過程,10.1.4 使用存儲過程 當(dāng)創(chuàng)建存儲過程時,需要確定存儲過程的三個組成部分: 1) 所有的輸入?yún)?shù)以及傳給調(diào)用者的輸出參數(shù)。 2) 被執(zhí)行的針對數(shù)據(jù)庫的操作語句,包括調(diào)用其它存儲過程的語句。 3) 返回給調(diào)用者的狀態(tài)值,以指明調(diào)用是成功還是失敗。 在SQL Server 2005中,創(chuàng)建存儲過程有兩種方法:一種是使用SQL Server Management Studio,另一種是使用T-SQL命令CREATE PROCEDURE。,,10.1 存儲過程,【例1】用SQL命令窗口創(chuàng)建存儲過程 CREATE PROC

7、EDURE GetStudent number varchar(40) AS SELECT * FROM student WHERE sno= number go EXECUTE GetStudent 95001,,10.1 存儲過程,【例2】創(chuàng)建帶有通配符參數(shù)的存儲過程 下面的存儲過程只從學(xué)生表中返回指定的一些學(xué)生(提供名字和姓氏)的信息。該存儲過程對傳遞的參數(shù)進行模式匹配,如果沒有提供參數(shù),則返回所有學(xué)生的信息。 CREATE PROCEDURE GetStudentByName name varchar(40) = % AS SELECT * FROM student W

8、HERE Sname LIKE name; EXECUTE GetStudentByName; 或者 EXECUTE GetStudentByName 劉%;,,10.1 存儲過程,【例3】創(chuàng)建使用output參數(shù)的存儲過程 下面的存儲過程從SC表中返回指定系的學(xué)生的平均成績。 CREATE PROCEDURE GetStudentAvgGradeByDept dept varchar(40),avggrade int out AS SET avggrade= (SELECT AVG(Grade) FROM SC WHERE sno in (SELECT SNO FROM stude

9、nt WHERE Sdept=dept)); GO DECLARE avggrade int EXEC GetStudentAvgGradeByDept cs,avggrade OUT PRINT avggrade,,10.1 存儲過程,【例4】使用sp_helptext查看存儲過程的源代碼 sp_helptext GetStudentAvgGradeByDept 說明:如果存儲過程使用WITH ENCRYPTION,其源代碼無法查看。 【例5】使用WITH ENCRYPTION創(chuàng)建存儲過程 CREATE PROCEDURE GetStudent1 number varchar(40) WI

10、TH ENCRYPTION AS SELECT * FROM student WHERE sno= number go,,10.1 存儲過程,10.1.5 重新編譯存儲過程 在執(zhí)行諸如添加索引或更改索引列中的數(shù)據(jù)等操作更改了數(shù)據(jù)庫時,應(yīng)重新編譯訪問數(shù)據(jù)庫表的原始查詢計劃以對其重新優(yōu)化。在SQL Server 2005重新啟動后,第一次運行存儲過程時自動執(zhí)行此優(yōu)化。當(dāng)存儲過程使用的基礎(chǔ)表發(fā)生變化時,也會自動執(zhí)行此優(yōu)化。但如果添加了存儲過程可能從中受益的新索引,將不會自動執(zhí)行優(yōu)化,直到下一次SQL Server重新啟動并再運行該存儲過程時為止。在這種情況下,強制在下次執(zhí)行存儲過程時對其重新編

11、譯會很有用。,,10.1 存儲過程,SQL Server中,強制重新編譯存儲過程的方式有三種: 1) sp_recompile系統(tǒng)存儲過程強制在下次執(zhí)行存儲過程時對其重新編譯。 2) 創(chuàng)建存儲過程時在其定義中指定WITH RECOMPILE選項,可以指明SQL Server將不為該存儲過程緩存計劃,在每次執(zhí)行該存儲過程時對其重新編譯。當(dāng)存儲過程的參數(shù)值在各次執(zhí)行間都有較大差異,導(dǎo)致每次均需創(chuàng)建不同的執(zhí)行計劃時,可使用WITH RECOMPILE選項。 3) 可以在執(zhí)行存儲過程時指定WITH RECOMPILE選項,強制對其重新編譯。,,10.1 存儲過程,觸發(fā)器是一種特殊的存儲過程,它在特定語

12、言事件發(fā)生時自動執(zhí)行。 這一節(jié)主要介紹觸發(fā)器的概念、作用以及其使用方法。,,10.2 觸發(fā)器,10.2.1 觸發(fā)器概述 觸發(fā)器是一種特殊類型的存儲過程,它不同于前面介紹過的存儲過程,主要是通過事件進行觸發(fā)而被執(zhí)行的,而存儲過程可以通過存儲過程名字而被直接調(diào)用。當(dāng)對某一表進行諸如UPDATE、INSERT、DELETE這些操作時,SQL Server就會自動執(zhí)行觸發(fā)器所定義的SQL語句,從而確保對數(shù)據(jù)的處理必須符合由這些SQL語句所定義的規(guī)則。,,10.2 觸發(fā)器,觸發(fā)器的主要作用就是實現(xiàn)由主鍵和外鍵所不能保證的復(fù)雜的參照完整性和數(shù)據(jù)一致性。除此之外,觸發(fā)器還有其它許多不同的功能: 1. 強化約

13、束(Enforce restriction) 2. 跟蹤變化(Auditing changes) 3. 級聯(lián)運行(Cascaded operation) 4. 存儲過程的調(diào)用(Stored procedure invocation),,10.2 觸發(fā)器,10.2.2 觸發(fā)器的類型 SQL Server 包括兩大類觸發(fā)器:DML觸發(fā)器和DDL觸發(fā)器。 1. DML觸發(fā)器 當(dāng)數(shù)據(jù)庫中發(fā)生數(shù)據(jù)操作語言(DML)事件時將調(diào)用DML觸發(fā)器。DML事件包括在指定表或視圖中修改數(shù)據(jù)的INSERT語句、UPDATE語句或DELETE語句。DML觸發(fā)器可以查詢其他表,還可以包含復(fù)雜的T-SQL語句。系統(tǒng)將觸發(fā)器

14、和觸發(fā)它的語句作為可在觸發(fā)器內(nèi)回滾的單個事務(wù)對待,如果檢測到錯誤(例如,磁盤空間不足),則整個事務(wù)即自動回滾。,,10.2 觸發(fā)器,SQL Server 2005的DML觸發(fā)器分為兩類:,After觸發(fā)器 這類觸發(fā)器是在記錄已經(jīng)改變完之后(after),才會被激活執(zhí)行,它主要是用于記錄變更后的處理或檢查,一旦發(fā)現(xiàn)錯誤,可以用Rollback Transaction語句來回滾本次的操作。 只能在表上定義。 Instead Of觸發(fā)器 INSTEAD OF 觸發(fā)器用來代替通常的觸發(fā)動作,即當(dāng)對表進行INSERT、UPDATE 或 DELETE 操作時,系統(tǒng)不是直接對表執(zhí)行這些操作,而是把操作內(nèi)容交

15、給觸發(fā)器,讓觸發(fā)器檢查所進行的操作是否正確。如正確才進行相應(yīng)的操作。因此,INSTEAD OF 觸發(fā)器的動作要早于表的約束處理。 可以在視圖上定義。,2. DDL觸發(fā)器 DDL觸發(fā)器是SQL Server 2005的新增功能。像常規(guī)觸發(fā)器一樣,DDL觸發(fā)器將激發(fā)存儲過程以響應(yīng)事件。但與DML觸發(fā)器不同的是,它們不會為響應(yīng)針對表或視圖的UPDATE、INSERT或DELETE語句而激發(fā),相反,它們會為響應(yīng)多種數(shù)據(jù)定義語言 (DDL)語句而激發(fā)。這些語句主要是以CREATE、ALTER和DROP開頭的語句。DDL觸發(fā)器可用于管理任務(wù),例如審核和控制數(shù)據(jù)庫操作。,,10.2 觸發(fā)器,10.2.3 觸

16、發(fā)器的設(shè)計規(guī)則 使用T-SQL語句CREATE TRIGGER可以創(chuàng)建觸發(fā)器。其語法格式如下: CREATE TRIGGER schema_name . trigger_name ON table | view WITH ,...n FOR | AFTER | INSTEAD OF INSERT , UPDATE , DELETE WITH APPEND NOT FOR REPLICATION AS sql_statement ; ...n | EXTERNAL NAME ,,10.2 觸發(fā)器,在SQL Server 2005里,為每個DML觸發(fā)器都定義了兩個特殊的表,一個

17、是插入表(inserted),一個是刪除表(deleted)。這兩個表是建在數(shù)據(jù)庫服務(wù)器的內(nèi)存中的,是由系統(tǒng)管理的邏輯表,而不是真正存儲在數(shù)據(jù)庫中的物理表。對于這兩個表,用戶只有讀取的權(quán)限,沒有修改的權(quán)限。這兩個表的結(jié)構(gòu)與觸發(fā)器所在數(shù)據(jù)表的結(jié)構(gòu)是完全一致的,當(dāng)觸發(fā)器的工作完成之后,這兩個表也將會從內(nèi)存中刪除。 插入表(inserted)里存放的是更新后的記錄:對于插入記錄操作來說,插入表里存放的是要插入的數(shù)據(jù);對于更新記錄操作來說,插入表里存放的是要更新的記錄。 刪除表(deleted)里存放的是更新前的記錄:對于更新記錄操作來說,刪除表里存放的是更新前的記錄(更新完后即被刪除);對于刪除記錄

18、操作來說,刪除表里存入的是被刪除的舊記錄。,,10.2 觸發(fā)器,DELETE觸發(fā)器是當(dāng)對表執(zhí)行DELETE操作時刪除元組,將刪除的元組放入deleted表中。檢查deleted表中的數(shù)據(jù),確定該如何處理。 INSERT觸發(fā)器在對執(zhí)行插入數(shù)據(jù)操作時,將插入表中的數(shù)據(jù)拷貝并送入inserted表中,根據(jù)inserted表中的值決定如何處理。 UPDATE觸發(fā)器僅在更新數(shù)據(jù)操作時將要被更新的原數(shù)據(jù)移入deleted表中,將更新后的數(shù)據(jù)備份送入inserted表中,對deleted和inserted表進行檢查,并決定如何處理。,,10.2 觸發(fā)器,10.2.4 使用觸發(fā)器 上面介紹了觸發(fā)器的概念、作用

19、和一些基本問題,下面將通過實例介紹在SQL Server 2005中如何使用觸發(fā)器。 【例6】創(chuàng)建DDL觸發(fā)器。 CREATE TRIGGER safety ON DATABASE FOR DROP_TABLE AS PRINT 不能修改表結(jié)構(gòu) ROLLBACK,,10.2 觸發(fā)器,【例7】創(chuàng)建DML觸發(fā)器。定義觸發(fā)器,要求學(xué)生已經(jīng)選修3門后,不能再選修課程 create trigger 選修限制 on SC after insert,update as if (select count(*) from SC,inserted where inserted.sno=SC.sno)=4 begi

20、n rollback transaction print 不能再選修課程 end go,,10.2 觸發(fā)器,【例8】創(chuàng)建DML觸發(fā)器,實現(xiàn)對學(xué)號的修改,注意表間無外鍵約束。 create trigger updateSno on student after update as declare oldSno char(5),newSno char(5) set oldSno=(select sno from deleted); set newSno=(select sno from inserted); Update SC set sno=newSno where sno=oldSno; gogo,,10.2 觸發(fā)器,

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

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!