SQL Server CLR 觸發程序執行個體

來源:互聯網
上載者:User

最近手頭上有一要解決的問題,就是在一個OA系統上跑工作流程,工作流程跑完後需要把批完的表單資料寫入到HR系統中。本想著寫一個小工具進行同步操作,但是又要告慮到即時問題,第一反應讓我想到的就是觸發器。

對頭,在SQL Sever裡面寫過一些觸發器,但是經常會用到一些遊標呀什麼的,總之覺得不爽。以前只是大至瞭解了一下SQL Server CLR,但是沒有真正使用過,這次來小試一下,看看效果如何。

 

大至實施起來分為以下幾部:

 

1.在VS中建立SQL SERVER 項目:

 

 

 

 

2.建立觸發器功能類

 

 

3.編寫實現功能的代碼

 

using System;<br />using System.Data;<br />using System.Data.SqlClient;<br />using Microsoft.SqlServer.Server;</p><p>public partial class Triggers<br />{<br /> // 為目標輸入現有表或視圖並取消對屬性行的注釋<br /> [Microsoft.SqlServer.Server.SqlTrigger(Name = "TriggerTest", Target = "t_SystemInfo", Event = "FOR UPDATE,INSERT")]<br /> public static void TriggerTest()<br /> {<br /> if (SqlContext.TriggerContext.TriggerAction == TriggerAction.Insert)<br /> {</p><p> //下面這一段就是需要觸發器需要完成的功能<br /> using (SqlConnection sqlcon = new SqlConnection("context connection=True"))<br /> {<br /> sqlcon.Open();<br /> SqlCommand sqlcom = sqlcon.CreateCommand();<br /> sqlcom.CommandText = "Select * from inserted";<br /> DataTable dt = new DataTable();<br /> SqlDataAdapter sqlda = new SqlDataAdapter(sqlcom);<br /> sqlda.Fill(dt);<br /> sqlcom.CommandText ="INSERT INTO [dbo].[test] ([msg]) VALUES('"+ dt.Rows[0]["ID"].ToString() + dt.Rows[0]["SystemName"].ToString()+"')";<br /> sqlcom.ExecuteNonQuery();<br /> }</p><p> }</p><p> }<br />}

 

 

4.建立SQL CLR 程式集

 

把剛才建立好的項目進行編譯,得到SqlServerProject1.dll檔案,為了示範方便,我在C盤根目錄下建立了一個CLR目錄,把SqlServerProject1.dll檔案複製到CLR目錄下

開啟SqlServer CLR:

EXEC sp_configure 'clr enabled',1

 

建立程式集

create assembly JomooCLR FROM 'c:/CLR/SqlServerProject1.dll' with permission_set= safe

 

以上紅色部門根據實際路徑替換

 

5.建立觸發器

 

create trigger mytrg on t_systeminfo
for insert
as
EXTERNAL NAME jomooclr.Triggers.TriggerTest

 

 

 

 

 

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.