一、使用CLR表值函数的背景
在SQL SERVER里面,直接读取远程数据库的表,似乎会占用大量的内存,出现类似错误:
链接服务器 "192.168.0.1" 的 OLE DB 访问接口 "SQLNCLI10" 报错。提供程序内存不足。 [SQLSTATE 42000] (错误 7399) 。
我不知道读取远程数据库的表是一个什么样的原理,是首先从远程将该表一古脑全部加载到本地内存,然后再根据过滤条件来获得相应的记录,还是这个过滤在远程服务器完成,然后返回找到的记录?
从占用大量内存来看,我觉得应该是前者。
如果在远程数据库里面提供一个函数,获取什么记录,都通过这个函数,这样返回来的就是少量的记录,绝大部分的数据处理都已在远端完成,御敌于国门之外。
但是远程数据库的函数是不能直接使用的,会报“不允许使用远程表值函数调用。
”的错误。存储过程可以,函数不行。只能通过OPENQUERY的方式来完成调用。但是,OPENQUERY又不能传递参数。(详见
如何给OPENQUERY传递参数
)
变通的办法是,在本地写一个CLR的表值函数,由它负责去访问远程函数,而本地访问它,等于间接访问远程函数。
之所以用CLR表值函数,是比较好传递参数给OPENQUERY,并且获得返回记录后,又能够装配好返回给本地调用方。假如不是函数而是存储过程,我都不知道调用方怎么去获取到这些记录。
二、编写CLR表值函数
三、部署CLR表值函数
1、 代码编写完后,编译成DLL。然后打开SQL SERVER的目标数据库 --》程序集 --》添加程序集,将DLL导入。给该程序集起个名字,比如叫myClrDll
2、如果代码更改,重新编译成DLL,可以用以下语句重新导入
ALTER ASSEMBLY [myClrDll]
FROM 'd:/code/temp/myClrDll.dll'
注意'd:/code/temp/myClrDll.dll'一定是数据库所在机器的路径。通常我们程序和数据库不同机器,所以这个路径常常搞错。
3、创建数据库表值函数,以使用这个CLR表值函数
USE [mydb]
GO
CREATE FUNCTION [dbo].[cr_func_getdatabyId](@Id [int])
RETURNS TABLE (
[Id] [int] NULL,
[Name] [nvarchar](300) NULL,--VARCHAR不行,要用NVARCHAR
[CreateDate] [smalldatetime] NULL
) WITH EXECUTE AS CALLER
AS
EXTERNAL NAME [myClrDll].[myFunc].[GetDataById]
完成,从此您可以幸福地使用函数cr_func_getdatabyId鸟。
分享到:
相关推荐
本文介绍了如何使用SQL Server中的表值函数来扩展SQL Server Reporting Services的数据访问功能。表值函数让编程人员和报表设计员有一定的灵活性,使他们能够实现数据不直接存储在数据库表中的报表制作场景。
SQL SERVER CLR 的讲解,如果配置CLR,及一个CLR 库的文档 ,可以针对例子,编写自已的CLR 函数.
必须SQLSERVER2005以上,支持CLR函数才行。 其中Concatenate是拼接字符串的聚合函数,MaxOther是某列最大时获取另外一列值的聚合函数,MinOther则反之。 Regex开头的函数是正则相关的函数。GetCodeTable是拆分字符串...
CLR扩展DLL 在MS-SQL Server 环境中实现文件、目录操作,程序使用VS2010编写,语言Vb.net。运行起来飞一般的感觉! 包含文件、目录操作的常用20多个函数,支持网络访问文件。 我经过5~6年的使用,实现用SQL管理复杂...
本书涵盖了T-SQL程序设计的方方面面,如基于集合的编程技术、日期和时间相关的XML和CLR数据类型的使用、临时对象、T-SQL和CLR用户自定义函数、存储过程、触发器、事务和新的错误处理结构、应用并发模型支持并发用户...
不管是SQL SERVER 2005还是SQL 2008 都没有提供字符串的聚合函数,但是 SQL 2005以后的版本支持CLR扩展系统的函数,所以就使用VS2010写了一个. 以后可以这样写了 select Age,dbo.joinstr(UserName,',',0) Name From ...
使用T-SQL或CLR在SQL Server中提供阵列功能
因工作时常在SQLSERVER进行http接口操作,涉及编码的转换问题和中文MD5的加密问题,在数据库中根本无法实现,经研究可以借助CLR功能实现一下函数。 附件中提供了源码、开启CLR脚本及直接注册一下函数的脚本,无c#...
在开始安装 SQL Server 之前,系统配置检查器 (SCC) 会验证性能监视器计数器注册表项的值。如果 SCC 无法验证现有的注册表项,或者 SCC 无法运行 Lodctr.exe 系统程序,则 SCC 检查会失败,并且安装程序会被阻止。若...
基于C#+CLR 技术创建一个Date转换函数for SQL Server。
为此采用SQLServer CLR功能,引入Newtonsoft.Json的方法进行对比,得到想要的结果。示例如下: select dbo.IsSameJson('{"ColA":"Value1", "ColB":"Value2"}', '{"ColB":"Value2", "ColA":"Value1"}') --结果:1 ...
本文主要介绍的是使用 FORMAT函数将日期/时间和数字值格式化为识别区域设置的字符串。下面话不多说,来看详细的介绍吧。 格式如下: format(value,format,culture) 第一个参数是要格式化的值,第二个是格式,第三...
因此,有时您需要编写一些“狗屎”sp,因为没有合适的实用程序。
SqlServerSlackAPI是一个SQL Server CLR程序集,用于通过TSQL与Slack直接通信 ##目录 用法 SlackChatPostMessage 表值函数通过HTTP将消息发布到Slack Channel API并解析json响应。 参数 名称 类型 必需的 描述...
8.4 视图与表值函数 8.4.1 一般用法 8.4.2 使用视图实现可配置的行级安全 8.5 数据混淆 8.6 监视与审核 8.6.1 服务器与数据库审核 8.6.2 使用DML触发器查看表的变更历史 8.6.3 DDL触发器 ...
按照微软所述,通过宿主 Microsoft .NET Framework 2.0 公共语言运行库 (CLR),SQL Server 2005显著地增强了数据库编程模型。 这使得开发人员可以用任何CLR语言(如C#、VB.NET或C++等)来写存储过程、触发器和用户...
1.系统表sysobjects 在数据库中创建的每个对象(例如约束、默认值、日志、规则以及存储过程)都对应一行。 列名 数据类型 ...FT = 程序集 (CLR) 表值函数 IF = 内联表函数 IT = 内部表 P = 存储
之前曾有一篇POST是关于用CTE实现Split,这种方法已经比传统的方法高效了。今天我们就这个方法与CLR实现的Split做比较。在CLR实现Split函数的确很简单,dotnet framework本身就有这个function了。
很早就知道可以用.NET为SQL Server2005及以上版本...首先要说明的是要在SQLServer中启用CLR必须是在SQLServer2005及以上版本,其次在默认情况下是没有启用CLR的,必须要显示设置为启用。比如我们要在ArticleCollectorD
因为 Transact-SQL 语句本身保持不变,仅参数值发生变化,所以 SQL Server 查询优化器可能重复使用首次执行时所生成的执行计划。 说通俗一点就是:如果用 EXEC 执行一条动态 SQL 语句,由于每次传入的参数不一样,...