`

SQLServer 2005触发器调用批处理文件

 
阅读更多

1.首先在Visual Stdio 2005中建立一个VB 数据库Sql Server 工程,工程名为【MyCLRProcedure】,如下图


2.选择数据库链接

3.在新建工程上右键 → 追加 → StoredProcedures,选择StoredProcedures ,设置名称为【MyProc.vb】,程序如下

PartialPublicClassStoredProceduresClassStoredProcedures
<Microsoft.SqlServer.Server.SqlProcedure()>_
PublicSharedSubMyProc()SubMyProc()
'コードをここに追加してください
EndSub

EndClass

在绿色注释部分追加调用bat文件的操作,本例是创建一个文件夹,带一个参数做为文件夹名。
run.bat文件内容如下:

@echo■■■TriggerTestStart■■■
if"%1"==""gotoEND
setDIRNAME=%1

rmdirc:temp%DIRNAME%
mkdirc:temp%DIRNAME%

:END
@echo■■■TriggerTestEnd■■■
pause

修改MyProc方法如下,追加一个参数【dirname】做为文件夹名:

PublicSharedSubMyProc()SubMyProc(ByValdirnameAsString)
'コードをここに追加してください
SqlContext.Pipe.Send("MyProcStart!")
Try
DimobjExecuteFileAsNewSystem.Diagnostics.ProcessStartInfo
DimobjExecuteAsNewSystem.Diagnostics.Process
objExecuteFile.FileName="c: emp un.bat"
SqlContext.Pipe.Send(objExecuteFile.FileName)
objExecuteFile.Arguments=dirname
objExecuteFile.UseShellExecute
=True
objExecute.StartInfo
=objExecuteFile
objExecute.Start()
CatchexAsException
SqlContext.Pipe.Send(ex.ToString)
EndTry
SqlContext.Pipe.Send(
"MyProc End!")
EndSub

将做成的【MyProc.vb】拷贝到【D:】盘根目录,打开【Microsoft .NET Framework SDK v2.0】 → 【SDK Command Prompt】,键入以下命令

C:ProgramFilesMicrosoftVisualStudio8SDKv2.0>vbc/target:libraryD:MyProc.vb
Microsoft(R)VisualBasicCompilerVersion
8.0.50727.42
forMicrosoft(R).NETFrameworkversion
2.0.50727.42
Copyright(C)MicrosoftCorporation.Allrightsreserved.


C:ProgramFilesMicrosoftVisualStudio
8SDKv2.0>

生成【MyProc.dll】文件,拷贝至数据库服务器上的【C:/temp】目录下。

4.打开【Microsoft SQL Server 2005】 → 【SQL Server Management Studio】,在【DataBase】 【数据库名】 【Programming】 【ASSEMBLY】上右键选中【New ASSEMBLY】,弹出新窗口,选择上步生成的【MyProc.dll】文件。

点击OK即可

5.建立一个Procedure,在上步【ASSEMBLY】同级别目录下选择【StoredProcedures】,右键新建一个【StoredProcedures】,修改内容为如下表示:

CREATEPROCEDUREMyProcedure
@dirnamenchar(10)
AS
EXTERNALNAMEMyProc.SqlServerProject.MyProc

6.在需要操作的数据表下的【Trigger】上右键选择新建,修改为如下:
CREATETRIGGERMyTrigger
ONDateTable
AFTER
INSERT,DELETE,UPDATE
AS
EXECMyProcedureAABBCC

其中【AABBCC】为传入的参数。点击OK,创建完毕,下面进行测试。

7.执行数据表删除语句,查看后台信息。

DELETEFROMDateTablewhereid='11'

后台信息如下:
MyProc Start!
c:/temp/run.bat
MyProc End!

(1 行処理されました)

再看服务器上【C:/temp】目录下,新建了一个【AABBCC】文件夹。

分享到:
评论

相关推荐

    SQL Server 2008高级程序设计 4/6

    SQL Server 2008高级程序设计 4/6 SQL Server 2008 2010 高级程序设计 作者:(美)维埃拉 著,杨华,腾灵灵 译 出版社:清华大学 出版日期:2010-4-1 ISBN:9787302222729 字数:1250000 页码:730 ----------------...

    SQL Server 2008高级程序设计 2/6

    《SQL Server 2008高级程序设计》由世界顶尖SQL Server权威专家Robert Vieira编写,旨在指导您熟练运用一系列日趋复杂的功能,助您更高效地管理数据。  本书首先介绍SQL Server 2008的新功能,然后在更详实的示例...

    SQL Server 2008编程入门经典(第3版)

    第1章 RDBMS基础:SQLServer数据库的构成 1.1 数据库对象概述 1.1.1 数据库对象 1.1.2 事务日志 1.1.3 最基本的数据库对象:表 1.1.4 文件组 1.1.5 数据库关系图 1.1.6 视图 1.1.7 存储过程 1.1.8 用户自定义函数 ...

    SQL Server 2008高级程序设计 5/6

    SQL Server 2008高级程序设计 5/6 SQL Server 2008 2010 高级程序设计 作者:(美)维埃拉 著,杨华,腾灵灵 译 出版社:清华大学 出版日期:2010-4-1 ISBN:9787302222729 字数:1250000 页码:730 ----------------...

    SQL Server 2008高级程序设计 6/6

    SQL Server 2008高级程序设计 6/6 SQL Server 2008 2010 高级程序设计 作者:(美)维埃拉 著,杨华,腾灵灵 译 出版社:清华大学 出版日期:2010-4-1 ISBN:9787302222729 字数:1250000 页码:730 ----------------...

    SQL.Server.2008编程入门经典(第3版).part2.rar

    第1章 RDBMS基础:SQLServer数据库的构成 1.1 数据库对象概述 1.1.1 数据库对象 1.1.2 事务日志 1.1.3 最基本的数据库对象:表 1.1.4 文件组 1.1.5 数据库关系图 1.1.6 视图 1.1.7 存储过程 1.1.8 用户自定义函数 ...

    SQL Server 2008高级程序设计 1/6

    《SQL Server 2008高级程序设计》由世界顶尖SQL Server权威专家Robert Vieira编写,旨在指导您熟练运用一系列日趋复杂的功能,助您更高效地管理数据。  本书首先介绍SQL Server 2008的新功能,然后在更详实的示例...

    SQL Server 2008高级程序设计 3/6

    《SQL Server 2008高级程序设计》由世界顶尖SQL Server权威专家Robert Vieira编写,旨在指导您熟练运用一系列日趋复杂的功能,助您更高效地管理数据。  本书首先介绍SQL Server 2008的新功能,然后在更详实的示例...

    SQL.Server.2008编程入门经典(第3版).part1.rar

    第1章 RDBMS基础:SQLServer数据库的构成 1.1 数据库对象概述 1.1.1 数据库对象 1.1.2 事务日志 1.1.3 最基本的数据库对象:表 1.1.4 文件组 1.1.5 数据库关系图 1.1.6 视图 1.1.7 存储过程 1.1.8 用户自定义函数 ...

    精通sql结构化查询语句

    23.4 对数据库中表的操作 23.4.1 向表中添加记录 23.4.2 浏览表中记录 23.4.3 修改已有记录 23.4.4 删除指定记录 23.5 可回复留言板的开发(PHP+SQL Server) 23.5.1 数据表的设计 23.5.2 配置文件的创建 23.5.3 创建...

    C#开发经验技巧宝典

    0956 C#中附加单文件SQL Server数据库 559 0957 备份SQL Server数据库 559 0958 还原SQL Server数据库 560 0959 开启SQL Server数据库服务 561 0960 断开SQL Server数据库服务 562 0961 如何判断SQL ...

    Java开发实战1200例(第1卷).(清华出版.李钟尉.陈丹丹).part3

    实例157 动态调用类中的方法 204 实例158 动态实例化类 205 实例159 创建长度可变的数组 206 实例160 利用反射重写toString()方法 208 实例161 反射与动态代理 209 7.3 常见的未检查型异常 210 实例162 算数异常 210...

Global site tag (gtag.js) - Google Analytics