當前位置:首頁 » 存儲配置 » 存儲過程和觸發器

存儲過程和觸發器

發布時間: 2022-02-15 02:10:15

1. 簡單說說存儲過程與觸發器的概念與作用

存儲過程就是一個sql的程序集 可以包含多個SQL語句 並可以附帶各種邏輯判斷及處理

觸發器 就類似於程序里的事件觸發
只是這里通常是某個欄位的改變 某個表插入了數據 或者刪除某些數據
以上這些處理引發的另外一些表數據的改變

2. 誰能解釋一下資料庫的存儲過程和觸發器

今年初寫的兩篇文章,正好是關於存儲過程和觸發器的,樓主可以參考一下。
1、SQL SERVER資料庫開發之存儲過程應用
http://bbs.51js.com/viewthread.php?tid=51505&fpage=1
2、SQL SERVER資料庫開發之觸發器的應用
http://bbs.51js.com/viewthread.php?tid=52487&fpage=1

3. 存儲過程和觸發器的區別

一、參考不同

1、存儲過程:是大型的SQL語句集,用於在大型資料庫系統中完成特定的功能。

2、初始化:SQLServer提供給程序員和數據分析人員以確保數據初始化的一種方法。

二、特點不同

1、存儲過程:存儲在資料庫中,編譯後永久有效,用戶通過指定存儲過程的名稱並指定參數(如果存儲過程具有參數)來執行。

2、insert:是與表事件相關的特殊存儲過程,程序的執行不被程序調用,也不是由程序手動啟動,而是由事件觸發,以便在操作表時(插入,刪除,更新))執行將被激活。

三、作用不同

1、存儲過程:以兩個遏制號(##)開頭的官僚存儲過程,該存儲過程將成為存儲在tempdb資料庫中的臨時存儲過程,一旦創建了該臨時存儲過程,它將被連接到伺服器稍後。任何用戶都可以在沒有特殊許可權的情況下執行它。

2、設置為:可用於強制引用常量,在添加,更新或刪除多個表中的行時終止,保留這些表之間定義的關系。但是,強制引用替換的最佳方法是在相關表中定義主鍵和外鍵約束。

4. SQL中存儲過程與觸發器的區別

存儲過程相當於一個函數,需要自己調用,觸發器是自動執行不需要調用

5. 存儲過程與觸發器的區別

觸發器與存儲過程非常相似,觸發器也是SQL語句集,兩者唯一的區別是觸發器不能用EXECUTE語句調用,而是在用戶執行Transact-SQL語句時自動觸發(激活)執行。觸發器是在一個修改了指定表中的數據時執行的存儲過程。通常通過創建觸發器來強制實現不同表中的邏輯相關數據的引用完整性和一致性。由於用戶不能繞過觸發器,所以可以用它來強制實施復雜的業務規則,以確保數據的完整性。觸發器不同於存儲過程,觸發器主要是通過事件執行觸發而被執行的,而存儲過程可以通過存儲過程名稱名字而直接調用。當對某一表進行諸如UPDATE、INSERT、DELETE這些操作時,SQLSERVER就會自動執行觸發器所定義的SQL語句,從而確保對數據的處理必須符合這些SQL語句所定義的規則。

6. 存儲過程與觸發器的區別和聯系

我的理解:主要是使用場合不同,還有就是觸發器中不能使用commit(這個應該是約定而不是規定)
存儲過程相當於打包好的sql語法,可以包含復雜的sql操作,在程序調用時只要執行該存儲過程,一句話就可以完成復雜的資料庫操作.

7. 簡述觸發器與存儲過程的區別。

存儲過程,你調用的時候才會執行
觸發器就是你設定了資料庫里比如刪除,修改,插入時,就會觸發

8. 觸發器與存儲過程的區別是什麼

首先介紹一下觸發器:
觸發器是一種特殊類型的存儲過程,當使用下面的一種或多種數據修改操作在指定表中對數據進行修改時,觸發器會生效:UPDATE、INSERT 或 DELETE。觸發器可以查詢其它表,而且可以包含復雜的 SQL 語句。它們主要用於強制復雜的業務規則或要求。例如,可以控制是否允許基於顧客的當前帳戶狀態插入定單。

觸發器還有助於強制引用完整性,以便在添加、更新或刪除表中的行時保留表之間已定義的關系。然而,強制引用完整性的最好方法是在相關表中定義主鍵和外鍵約束。如果使用資料庫關系圖,則可以在表之間創建關系以自動創建外鍵約束。有關詳細信息,請參見表關系。

使用觸發器的優點
觸發器的優點如下:

觸發器是自動的:它們在對表的數據作了任何修改(比如手工輸入或者應用程序採取的操作)之後立即被激活。

觸發器可以通過資料庫中的相關表進行層疊更改。例如,可以在 titles 表的 title_id 列上寫入一個刪除觸發器,以使其它表中的各匹配行採取刪除操作。該觸發器用 title_id 列作為唯一鍵,在 titleauthor、sales 及 roysched 表中對各匹配行進行定位。

觸發器可以強制限制,這些限制比用 CHECK 約束所定義的更復雜。與 CHECK 約束不同的是,觸發器可以引用其它表中的列。
再介紹存儲過程:
存儲過程(Stored Procere)是一組為了完成特定功能的SQL語句集,經編譯後存儲在資料庫中。用戶通過指定存儲過程的名字並給出參數(如果該存儲過程帶有參數)來執行它。存儲過程是資料庫中的一個重要對象,任何一個設計良好的資料庫應用程序都應該用到存儲過程。總的來說,存儲過程具有以下一些優點:

◆存儲過程允許標准組件式編程

◆存儲過程能夠實現較快的執行速度

◆存儲過程能夠減少網路流量

◆存儲過程可被作為一種安全機制來充分利用

使用 SQL Server 中的存儲過程而不使用存儲在客戶計算機本地的 Transact-SQL 程序的優勢有:

允許模塊化程序設計。
只需創建過程一次並將其存儲在資料庫中,以後即可在程序中調用該過程任意次。存儲過程可由在資料庫編程方面有專長的人員創建,並可獨立於程序源代碼而單獨修改。

允許更快執行。
如果某操作需要大量 Transact-SQL 代碼或需重復執行,存儲過程將比 Transact-SQL 批代碼的執行要快。將在創建存儲過程時對其進行分析和優化,並可在首次執行該過程後使用該過程的內存中版本。每次運行 Transact-SQL 語句時,都要從客戶端重復發送,並且在 SQL Server 每次執行這些語句時,都要對其進行編譯和優化。

減少網路流量。
一個需要數百行 Transact-SQL 代碼的操作由一條執行過程代碼的單獨語句就可實現,而不需要在網路中發送數百行代碼。

可作為安全機制使用。
即使對於沒有直接執行存儲過程中語句的許可權的用戶,也可授予他們執行該存儲過程的許可權

9. 存儲過程和觸發器

PROCEDURE
p_book1
PROCEDURE p_book2
書名='大學英語'
EXEC p_book2
圖書編號=@x
'001105'
varchar(20)
書籍表 where 書名=@c1
EXEC p_book4 '大學語文'

熱點內容
愛感大黑牛怎麼連接安卓手機 發布:2025-02-04 04:41:31 瀏覽:218
publicftp 發布:2025-02-04 04:41:26 瀏覽:71
sqlserver超時 發布:2025-02-04 04:39:58 瀏覽:70
網路推理演算法 發布:2025-02-04 04:37:00 瀏覽:260
c怎麼存儲數據 發布:2025-02-04 04:31:12 瀏覽:63
奧迪q3行駛證如何查配置 發布:2025-02-04 04:28:26 瀏覽:329
ebay商品上傳 發布:2025-02-04 04:23:38 瀏覽:83
linux嵌入式書籍 發布:2025-02-04 03:44:07 瀏覽:334
sql分組最後一條 發布:2025-02-04 03:38:24 瀏覽:272
單宮數字奇門演算法 發布:2025-02-04 03:33:57 瀏覽:865