手工部署Sqlserver CLR程序集
以前一直用VS部署Sqlserver CLR程序集简单省事,现在服务器部署在内网了,必须手动更新部署Sqlserver CLR程序集。
开始以为ALTER ASSEMBLY [程序集名称] FROM 'G:\AA\XX.dll'这样就OK,没想到出错然后查资料越弄越复杂,看来手工部署远没想象中这么简单,于是好好研究了一番最后终于成功,具体步骤是:
1.如果以前部署过当前程序集,则必须先删除引用当前程序集的所有模块(各类函数和存储过程等),然后删除当前程序集。
2.重新部署当前程序集,然后再创建相关模块(各类函数和存储过程等)。
以下是一个sql模板,有需要的可以套一下:
-- ================================= 删除先 ================================= -- -- MyCLRSqlserver 为程序集部署名称 IF EXISTS ( SELECT * FROM sys.assemblies asms WHERE asms. name = N 'MyCLRSqlserver' and is_user_defined = 1) BEGIN -- 删除集合函数。 IF EXISTS ( SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N '[dbo].[StrJoin]' ) AND type = N 'AF' ) DROP AGGREGATE dbo.StrJoin; -- 删除标量函数。 IF EXISTS ( SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N '[dbo].[___fun_CLR_ChangeSalarieScope]' ) AND type in (N 'FN' , N 'IF' , N 'TF' , N 'FS' , N 'FT' )) DROP FUNCTION dbo.___fun_CLR_ChangeSalarieScope; -- 删除其它... -- 卸载程序集。 DROP ASSEMBLY [MyCLRSqlserver]; END ; -- ================================= 重新创建 ================================= -- -- 注册程序集(如果是在服务器上部署,需要将此dll复制到服务器,然后修改文件地址)。 CREATE ASSEMBLY [MyCLRSqlserver] FROM 'G:\AA\XX.dll' ; ---------------------- [dbo].[StrJoin] ---------------------- CREATE AGGREGATE [dbo].[StrJoin] (@Value [nvarchar](4000)) RETURNS [nvarchar](4000) EXTERNAL NAME [MyCLRSqlserver].[MyCLRSqlserver.StrJoin] GO EXEC sys.sp_addextendedproperty @ name =N 'AutoDeployed' , @value=N 'yes' , @level0type=N 'SCHEMA' ,@level0name=N 'dbo' , @level1type=N 'AGGREGATE' ,@level1name=N 'StrJoin' GO EXEC sys.sp_addextendedproperty @ name =N 'SqlAssemblyFile' , @value=N 'StrJoin.cs' , @level0type=N 'SCHEMA' ,@level0name=N 'dbo' , @level1type=N 'AGGREGATE' ,@level1name=N 'StrJoin' GO EXEC sys.sp_addextendedproperty @ name =N 'SqlAssemblyFileLine' , @value=14 , @level0type=N 'SCHEMA' ,@level0name=N 'dbo' , @level1type=N 'AGGREGATE' ,@level1name=N 'StrJoin' GO -- 其它函数创建过程... -- ================================= END ================================= -- |
以上是手工创建过程比较麻烦,当然如果模块不多的话这样也没问题,如果很多的话可以查当前数据库的系统视图assembly_modules获取所有CLR模块,然后写代码自动生成模块DROP和CREATE过程。
以上是本人手工部署Sqlserver CLR程序集过程,在此做个记录方便以后随时翻阅,同时也给没有手工部署经验的同学提供参考,如果哪位有更方便智能的方法敬请告之,谢谢!
手工部署Sqlserver CLR程序集的更多相关文章
- MSSQLSERVER添加c# clr程序集的使用方法
前言 MSSQLSERVER提供程序集,无疑可以让编程人员更加便捷的操作数据库数据,比如c#写的函数,可以在数据库当作sql的函数使用,你想想他对不熟悉数据库的程序员来说是有多么的嗨.这么好的机制,大 ...
- 在SQL2005中部署CLR 程序集
原文 在SQL2005中部署CLR 程序集 有关于CLR函数的用途和用法,请了解 SQL Server CLR 极速入门,启用.设计.部署.运行 http://www.yongfa365.com/It ...
- 手工部署yugabyte的几点说明
ntp 时间同步 ntp 时间同步对于yugabyte 是一个比较重要的服务,需要注意时间的同步 YB-Master 个数的说明 原则 YB-Master 的个数,必须和复制因子的个数一样,同时mas ...
- Kubernetes 基于 ubuntu18.04 手工部署 (k8s)
由于工作的需要, 手工部署一个 Kubernetes 环境(k8s).(以前都是云上搞定,拿来用) 习惯把这种工作记录下来,自己备查也和别人分享 网上相关文章很多, 我也参考了很多,这里推荐一个 链接 ...
- 脱离OBDeploy工具,手工部署OceanBase方法
[简介] OBDeploy是OceanBase集群部署的工具,可以通过简单的几行命令,就能快速的进行OceanBase部署.但对于初学者来讲,可能会比较困惑,Deploy到底做了哪些事情?里面的具体步 ...
- SQL Server 部署CLR程序集错误`6218`
Visual Studio 2015中开发的SQL Server项目,添加了用户自定义函数,需要部署到SQL Server 2005上, 在部署时报错: (70,1): SQL72014: .Net ...
- 新服务器部署sqlserver之前的准备
当你有一个新的服务器需要部署的时候,如果没有部署过的经验很可能会走很多误区,并且给以后的维护工作加大难度,我在这就把我部署服务器的一些经验跟大家分享一下. 1.登陆服务器以后先将物理盘按照64k为分配 ...
- 在Ubuntu16.04集群上手工部署Kubernetes(未完,陆续补充中)
主机信息 主机 IP OS k8s-master 10.10.10.20192.168.0.20 Ubuntu Server 16.04 k8s-node1 10.10.10.21192.168.0. ...
- 使用docker部署SqlServer
踩了很多坑,来记录一下 首先说sqlserver 1. 安装docker要使用centos 7以上版本,使用centos 6及以下版本会出现各种问题 2. docker CE安装过程 $ sudo y ...
随机推荐
- JavaSE思维导图(五)
- hbase 单机安装问题
报zookeeper exception not found I fixed this by editing the file "/usr/local/hbase-0.94.1/conf/h ...
- wcf客户端 cookie
public class CookieBehavior:IEndpointBehavior { private string _cookie; #region 构造函数 重载+2 public Coo ...
- C# 微信公众平台开发(1)-- 服务器配置
题记:最近公司需要开发微信服务号,由本人负责,以前虽然听过微信开发,但并没有认真的去了解,项目开发中,也边看文档边开发,记录自己的项目开发经验: 1.注册帐号--填写服务器配置 在https://mp ...
- 面试常用算法——Longest Palindromic Substring(最长回文子串)
第一种: public static void main(String[] args) { String s = "abcbaaaaabcdcba"; int n,m; Strin ...
- The error indicates that IIS is in 32 bit mode, while this application is a 64 b it application and thus not compatible.
I was trying to install a new WSS v3 Sharepoint on a 64 bit Windows 2003 server today but the instal ...
- ACCP6.0 教程课件,可用
下载地址 求分 http://download.csdn.net/detail/qq873113580/6038955 包含ACCP6.0所有,是我朋友的自己保存的,请大家不要修改密码,谢谢 下面就是 ...
- CCNA实验(8) -- PPP & HDLC
HDLC帧格式与以太帧格式有很大差别,HDLC帧没有源MAC和目的MAC地址.HDLC不能提供验证,缺少对链路保护.Cisco设备与Cisco设备连接,可用HDLC封装.Cisco设备与非Cisco设 ...
- windows 下面的内存泄漏排查.
内存泄漏排查 一下本人只是简单的介绍一个实用, 如果读者很感兴趣, 可以查阅msdn自己去深入调查相关的API和原理. API 介绍 1. 马上打印泄漏信息:_CrtDumpMemoryLeaks() ...
- C(n+m,m) mod p的一类算法
Lucas定理 A.B是非负整数,p是质数.AB写成p进制:A=a[n]a[n-1]...a[0],B=b[n]b[n-1]...b[0]. 则组合数C(A,B)与C(a[n],b[n])*C(a[n ...