读书人

提一个关于SQL Server 2005的CLR的有关

发布时间: 2012-01-26 19:40:46 作者: rapoo

提一个关于SQL Server 2005的CLR的问题,请了解的人帮帮我...
要在数据库中实现一个复杂逻辑.但这个复杂的逻辑已经用C#程序已经实现(如果再用T-SQL来实现一次的话,有相当的难度和工作量)

现在想把C#所实现的程序封装成为方法.
利用SQL的CLR,在数据库中使用,

但这个封装好的方法中使用了一些数库操作.还有读Web.config节的地方.
现在把DLL 放入SQL CLR中 ,运行时报错.错误信息意思是读不到web.cofing这里面的内容.

这样问题应该怎么解决.???
请了解的朋友给些意见/

这是将DLL注册到CLR中

USE EngineDB
GO

EXEC sp_changedbowner 'sa '


Alter Database EngineDB
SET TRUSTWORTHY ON
go


create assembly MHLSQLFunction

FROM 'E:\Engine\iSec\SqlServerProject1\bin\Debug\SqlServerProject1.dll '

WITH permission_set = UNSAFE;

错误信息:
消息 6522,级别 16,状态 2,第 1 行
在执行用户定义例程或聚合 ' ' 期间出现 .NET Framework 错误:
System.NullReferenceException: Object reference not set to an instance of an object.
System.NullReferenceException:
at BC.Engine.DBHelper.SysConfig.GetConfigString(String name)
at BC.Engine.DBHelper.SysConfig.get_DataBaseType()
at BC.Engine.DBHelper.Factory.CreateDBAccess()
at BC.Engine.iSec.UserRight..ctor()
at BC.Engine.iSec.SecurityEngine..ctor()
at SqlServerProject1.Class1.GetUserRightList(SqlString userid)

-----------------------


at BC.Engine.DBHelper.SysConfig.GetConfigString(String name)
这句就是说明没有读到Web.config节


MSN:mmmhhhlll@hotmail.com

大家有了解的互相交流一下呀

[解决办法]
把Web.config中的要用到的数据放在一个xml文件中,然后读XML文件的数据,然后把dll和xml一起发布。
[解决办法]
没有做过

不过数据库的事还是交给数据库而不是程序效率更好些
[解决办法]
可以把web.config的内容封装到dll的初始化接口中
[解决办法]
可以考虑吧webconfig的内容写在存储过程里
然后存储过程传值给你的clr函数

[解决办法]
调用clr dll 的主线程是 sql server 2005 ,它怎么能读 web.cofing ?
[解决办法]
俩裤衩的来顶了.
[解决办法]
在一个表里存储web相关的设置

读取该表来得到相关的设置值
[解决办法]
clr可以做身份模拟,这样看来应该可以做磁盘的io
等等看谁做过这方面的事情
[解决办法]
可以用xml文件保存参数,xml文件是要绝对路径。
[解决办法]
参考这个,希望对lz有所帮助。
http://www.cnblogs.com/DavidFan/archive/2007/05/16/748300.html
不是道为什么,cnblogs老是很慢。

读书人网 >C#

热点推荐