在SQL2005中部署CLR 程序集
有关于CLR函数的用途和用法,请了解
SQL Server CLR 极速入门,启用、设计、部署、运行
http://www.yongfa365.com/Item/SQL-Server-CLR.html
由于项目要用到对超大型数据表进行关键字检索,一般使用LIKE语句就可以成功完成,但是据说使用CLR函数可以提供查询效率。
先试试再说
第一次使用SQLServer集成CLR,感觉很奇妙。这里分享一下如何部署CLR到新的数据库环境,比如远程数据库服务器。
一,在本地开发环境部署:
在本地开发环境,使用VS2010的部署功能就可以实现将CLR函数部署到数据库中。
注意:SQL Server 2005/2008/2008 R2使用的都是CLR 2.0所以,只能选择,2.0,3.0,3.5的.net framework
右键项目 - 选择“部署”。
然后打开"Sql Server Management Studio",查看是否部署成功。
在LINQ中使用用户自定义函数
打开DBML设计视图,左侧“服务器资源管理器"中,连接到数据库后,打开函数分支,将函数拖入右侧设计视图中。
在代码中利用自定义函数,LINQ查询:
在本地,我们已经实现了集成CLR函数查询。可是如何部署到远程SQL2005数据库中呢?
二,远程数据库部署CLR 程序集。
项目生成成功以后,在项目的文件目录的Bin\Debug\ 获取程序集文件。
其中我们需要将SqlServerProject1.dll在服务器SQL Server 2005环境中注册。
将文件拷贝到服务器后,尝试注册程序集:
- -- 注册程序集
- CREATE ASSEMBLY [SqlServerProject1] FROM 'D:\SQLCLR_DLL\SqlServerProject1.dll';
报告错误:
程序集 'SqlServerProject1' 所引用的程序集 'system.core, version=3.5.0.0, culture=neutral, publickeytoken=b77a5c561934e089.' 不在当前数据库中。
SQL Server 已尝试定位并自动从引用程序集所在的位置自动加载被引用程序集,但此操作失败(原因: 2(系统找不到指定的文件。))。请将被引用程序集加载到当前数据库中,然后重试您的请求。
这说明SQL SERVER并不支持System.Core.dll程序集,应先加载:
EXEC dbo.sp_changedbowner @loginame = N'sa', @map = true GO sp_configure 'clr enabled', 1 GO RECONFIGURE GO ALTER DATABASE [stzpbbs] SET TRUSTWORTHY ON GO CREATE ASSEMBLY [System.Core] AUTHORIZATION [dbo] FROM 'C:\Program Files\Reference Assemblies\Microsoft\Framework\v3.5\System.Core.dll' WITH PERMISSION_SET = UNSAFE GO
再次执行:
- -- 注册程序集
- CREATE ASSEMBLY [SqlServerProject1] FROM'D:\SQLCLR_DLL\SqlServerProject1.dll';
--命令成功完成。
将VS2010 部署脚本SqlServerProject1.sql加载到查询分析器:
执行时报告N多错误,我们改一改
主要有3个地方:
1.这里改成相应数据库实际的物理路径
:setvar DefaultDataPath "C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\DATA\"
:setvar DefaultLogPath "C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\DATA\"
2.改数据库名称(红色字部分)
GO
:on error exit
GO
USE [master]
GO
USE stzpbbs
GO
3.禁止回滚
到倒数第几行的位置
--IF EXISTS (SELECT * FROM #tmpErrors) ROLLBACK TRANSACTION
然后看看标量函数中是否包含有新建的自定义函数。
测试一下:
select * from bbs_posts where dbo.ContainsOne(posttitle,'我')=1
成功找到两条记录。
注意:操作之前应先将数据库编写脚本(包括数据)部署到远程数据库中。这里只是说明了如何部署CLR自定义函数.
如有错误,请指正,很少写博客。发现写文字和生孩子一样痛苦。:)
在SQL2005中部署CLR 程序集的更多相关文章
- SQL Server 部署CLR程序集错误`6218`
Visual Studio 2015中开发的SQL Server项目,添加了用户自定义函数,需要部署到SQL Server 2005上, 在部署时报错: (70,1): SQL72014: .Net ...
- 手工部署Sqlserver CLR程序集
原文 手工部署Sqlserver CLR程序集 以前一直用VS部署Sqlserver CLR程序集简单省事,现在服务器部署在内网了,必须手动更新部署Sqlserver CLR程序集. 开始以为A ...
- 重温CLR(二)生成、部署以及程序集
将类型生成到模块中 class Program { static void Main(string[] args) { Console.WriteLine("Hi"); } } 该 ...
- 【续集】在 IIS 中部署 ASP.NET 5 应用程序遭遇的问题
dudu 的一篇博文:在 IIS 中部署 ASP.NET 5 应用程序遭遇的问题 针对 IIS 部署 ASP.NET 5 应用程序的问题,在上面博文中主要采用两种方式尝试: VS2015 的 Publ ...
- MSSQLSERVER添加c# clr程序集的使用方法
前言 MSSQLSERVER提供程序集,无疑可以让编程人员更加便捷的操作数据库数据,比如c#写的函数,可以在数据库当作sql的函数使用,你想想他对不熟悉数据库的程序员来说是有多么的嗨.这么好的机制,大 ...
- SQL Server中的CLR编程——用.NET为SQL Server编写存储过程和函数
原文:SQL Server中的CLR编程--用.NET为SQL Server编写存储过程和函数 很早就知道可以用.NET为SQL Server2005及以上版本编写存储过程.触发器和存储过程的,不过之 ...
- 在SQL Server中使用CLR调用.NET类库中的方法 (转载)
在SQL Server中调用 .NET 类库的方法要分为下面几步来实现: 在.NET中新建一个类库项目,并在这个项目中添加一个类文件,并把要被SQL Server调用的方法定义为公有的,静态的方法. ...
- 在SQL Server中使用CLR调用.NET方法
介绍 我们一起来做个示例,在.NET中新建一个类,并在这个类里新建一个方法,然后在SQL Server中调用这个方法.按照微软所述,通过宿主 Microsoft .NET Framework 2 ...
- Intellij IDEA 创建Web项目并在Tomcat中部署运行(不使用maven)【转载】
原文链接:http://www.thinksaas.cn/topics/0/350/350000.html 一.创建Web项目 1.File -> New Module,进入创建项目窗口 2.选 ...
随机推荐
- 2014.9.3数据库CRUD
CRUD 增删改查 DCL 数据控制语言:备份,grant DML 数据操作语言: CRUD DDL 数据定义语言:create drop alter 自增长列不能赋值 增: Insert into ...
- class A<T> where T:class 这个泛型类中的Where T:class什么意思
这是类型参数约束,.NET支持的类型参数约束有以下五种: where T : struct T必须是一个结构类型 where T : cla ...
- TCP的流量控制
TCP协议作为一个可靠的面向字节流的传输协议,其可靠性和流量控制由滑动窗口协议保证,而拥塞控制则由控制窗口结合一系列的控制算法实现. 要区分TCP的流量控制和拥塞控制: 流量控制是发送方的发送数据的速 ...
- bzoj 3289: Mato的文件管理 莫队+线段树
题目链接 给一些询问,每个询问给出区间[L, R] , 求这段区间的逆序数. 先分块排序, 然后对于每次更改, 如果是更改L, 那么应该查询区间内比他小的数的个数, 如果更改R, 查区间内比他大的数的 ...
- Python2.7.3 学习——第一个程序 Hello Python World
Hello World 每学一门语言开始的第一程序都是Hello World ,当然了Python也不例外,下面开始我们的Python第一个程序编写: 1,命令行: (1)打开终端,输入python, ...
- ODI学习笔记2--ODI产品架构
ODI学习笔记2--ODI产品架构 ODI产品架构: ODI提供了以下几种管理工具:Designer 用于定义数据转换逻辑,这是最常用的开发工具,大部分的开发任务,包括data store的定义,in ...
- Android 5.x新特性之elevation(阴影),tinting(着色)以及clipping(剪裁)
快过年了,公司也没事做了, 自己也闲了下来,一天天呆着真没意思,闲来没事自己研究研究了Google I/O 2014 发布 Material Design设计,人性化的风格,丰富的色彩,使人机交互更完 ...
- php 前端获取数据
<pre name="code" class="python"><!doctype html> <html lang=" ...
- 快速学习使用 Windows Azure 上的 SharePoint Server 2013
为了在当今的企业环境中占据一席之地,您需要能够迅速顺应变化和应对挑战.有时,需要及时调整您的SharePoint 基础结构以保持竞争优势. 基础结构即服务可通过随时使用.即付即用的解决方案应对这 ...
- HDU 5773 The All-purpose Zero(树状数组)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5773 [题目大意] 给出一个非负整数序列,其中的0可以替换成任意整数,问替换后的最长严格上升序列长 ...