sql-server-2005 – 提取SQLCLR程序集

我们的一个内部应用程序有一个sqlCLR程序集,目前遇到问题.开发人员在使用存储在我们的源代码管理系统中的版本重新创建问题时遇到问题,因此他怀疑某些代码可能已经发布但未上传到源代码控制.有没有办法将sqlCLR程序集提取到.dll文件中,以便他可以对其进行反向工程以进行分析?

解决方法

确实有一种方法 – 程序集存储在数据库的sys.assembly_files表中.从sys.assembly_files中选择所有内容并找到assembly_id,然后运行以下代码(首先更改assembly_id和SavetoFile路径):
DECLARE @IMG_PATH VARBINARY(MAX)
DECLARE @ObjectToken INT

SELECT @IMG_PATH = content FROM sys.assembly_files WHERE assembly_id = 65536

EXEC sp_OACreate 'ADODB.Stream',@ObjectToken OUTPUT
        EXEC sp_OASetProperty @ObjectToken,'Type',1
        EXEC sp_OAMethod @ObjectToken,'Open'
        EXEC sp_OAMethod @ObjectToken,'Write',NULL,@IMG_PATH
        EXEC sp_OAMethod @ObjectToken,'SavetoFile','D:\sqlServerProject1.dll',2
        EXEC sp_OAMethod @ObjectToken,'Close'
        EXEC sp_OADestroy @ObjectToken

为了使其工作,您需要在sql实例的功能的Surface Area Configuration中启用OLE自动功能.

我从这里提取了这段代码
http://social.msdn.microsoft.com/Forums/en/sqlnetfx/thread/1e00e656-f322-45ec-b4e0-83db748fa97a

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...