SQLSERVER调用DLL程序
在SQL Server中调用dll分为两个步骤
1.创建一个dll文件(dll文件分成3种类型,讲其中一种)
2.把dll文件放进SQL Server的程序集中。然后定义一个Function,就可以通过该Function来引用dll中的函数。
1创建一个dll文件
1.1点击“文件”->“新建”->“项目”->类库,把命名空间改成TestDLL,添加如下代码
(框架必须改为.NET3.5及3.5以下,因为SQL Server 2008只是支持.NET 3.5及一下,.NET 4.0是2010年发布的,不支持也很正常,C#方法必须是静态方法,因为静态函数不用实例化类就可以调用)
创建dll程序(求和、小写字母转换成大写字母)
using System;
using System.Collections.Generic;
using System.Text; namespace TestDLL
{
public class Class1
{
//求0到n的和当n小于0时返回0
//方法必须为静态方法,因为静态函数不用实例化类就可以调用
public static int Calc(int n)
{
int sum;
sum = ;
if (n>=)
{
for (int i = ; i <= n; i++)
{
sum = sum + i;
}
return sum;
}
else
{
return ;
}
}
//将字符串转换成大写
public static string Todaxie(string s)
{
return s.ToUpper();
}
}
}
1.2右击“项目”,点击”生成“或者直接按F6
1.3右击“项目”,点击“在文件资源管理系统中打开文件夹”,点击bin->debug,然后就会看到一个TestDLL.dll文件。
2在SQL中引用dll文件
2.1允许SQL Server允许运行用户程序集
在SQL Server中运行如下代码:
EXEC sp_configure 'clr enabled' , ''; --0代表不允许,1代表运行
RECONFIGURE;
其中TestDll是你在数据库中为这个程序集起的名字。
2.3创建一个Function,使用该dll文件
使用如下SQL语句
--转换成大写字母
create FUNCTION [dbo].[ToUpper](@InputString [nvarchar](500))
RETURNS [nvarchar](200)
WITH EXECUTE AS CALLER
AS
EXTERNAL NAME [TestDLL].[TestDLL.Class1].[Todaxie]
GO
--求和函数
CREATE FUNCTION [dbo].[Calc](@n int) --该函数名字
RETURNS int --返回类型
WITH EXECUTE AS CALLER
AS
EXTERNAL NAME [TestDLL].[TestDLL.Class1].[Calc] --调用c#程序集
GO
注意一下的那几个单词。
TestDLL是指你程序集中dll的名称。
TestDLL是指dll文件中那个类的命名空间
Class1是指dll文件中那个类的类名
Todaxie是指dll文件中那个被调用的静态方法
最后,便可以这样来调用该函数
print dbo.ToUpper('abc') --输出的结果为ABC
SELECT dbo.Calc(3) --输出的结果为6
SQLSERVER调用DLL程序的更多相关文章
- C/C++:Windows编程—调用DLL程序的2种方法(转载)
文章为转载,原文出处https://blog.csdn.net/qq_29542611/article/details/86618902 前言先简单介绍下DLL.DLL:Dynamic Link Li ...
- DLL程序的创建步骤和測试程序
首先,创建DLL程序 然后,加入一个导出类 比如: //Test.h #pragma once class AFX_EXT_CLASS Test { public: Test(void); ~Te ...
- C#程序实现动态调用DLL的研究(转)
摘 要:在<csdn开发高手>2004年第03期中的<化功大法——将DLL嵌入EXE>一文,介绍了如何把一个动态链接库作为一个资源嵌入到可执行文件,在可执行文件运行时,自动从资 ...
- C#程序实现动态调用DLL的研究[转]
摘 要: 在< csdn 开发高手> 2004 年第 03 期中的<化功大法——将 DLL 嵌入 EXE >一文,介绍了如何把一个动态链接库作为一个资源嵌入到可执行文件,在 ...
- C#程序实现动态调用DLL的研究
摘 要:在<csdn开发高手>2004年第03期中的<化功大法——将DLL嵌入EXE>一文,介绍了如何把一个动态链接库作为一个资源嵌入到可执行文件,在可执行文件运行时,自动从资 ...
- 浅谈C++调用C#的DLL程序方法
把C#编译成DLL或者Axtive控件,再由C调用!比如使用C++调用C#的DLL. SwfDotNet是.net下输出flash的类库.SwfDotNet是C#编写的,作者的C#水平,真是令我佩服. ...
- 当程序调用dll时获取dll路径,DLL中获取自身的句柄
当程序调用dll时,获取dll路径的方法: HMODULE hMod = GetModuleHandle(_T("axload.dll")); if (hMod != NULL) ...
- SQL点滴15—在SQL Server 2008中调用C#程序
原文:SQL点滴15-在SQL Server 2008中调用C#程序 T-SQL的在执行普通的查询的时候是很高效的,但是在执行循环,判断这样的语句的时候效率就不那么的高了.这时可以借助CLR了,我们可 ...
- Window系统命令行调用控制面板程序
Window系统命令行调用控制面板程序 control.exe /name microsoft.folderoptions 启动资源管理器的 文件夹属性 选项卡 control.exe /name M ...
随机推荐
- viewDidLoad方法的调用顺序
https://www.evernote.com/shard/s227/sh/01307822-de66-448d-8bac-7954f01ffc64/185b44c2bf5b6e266f4bed ...
- 内核中的多点触摸协议文档 Multi【转】
转自:http://www.arm9home.net/read.php?tid=24754 前段时间改写了一个GT801的内核驱动,仔细阅读 MT Event 上报的时候,发现这个驱动是针对 Andr ...
- 2.flume架构以及核心组件
flume组件主要包含三部分 source:从各个地方收集数据 channel:聚集,相当于临时数据存放的地方.因为数据来的时候,不可能来一条便写一次,那样效率太低,而是先把数据放在通道里,等通道满了 ...
- JMeter 分布式测试部署
对于并发量很大的需求,如上万并发量,受到CPU和内存的限制,单机模拟场景是实现不了的,为了让JMeter提供更大的负载能力,须使用它的分布式机制,即多台机器同时产生负载的功能. 以下参数分析可用于配置 ...
- MyBatis3-实现多表关联数据的查询
前提: 1.新建Article表和增加模拟数据,脚本如下: Drop TABLE IF EXISTS `article`; Create TABLE `article` ( `id` ) NOT NU ...
- java使用maven项目(二)分模块开发
1 整合ssh框架 1.1 依赖传递 只添加了一个struts2-core依赖,发现项目中出现了很多jar, 这种情况 叫 依赖传递 1.2 依赖版本冲突的解决 1. 第 ...
- AC日记——LOOPS hdu 3853
3853 思路: 概率dp求期望: 代码: #include <cstdio> #include <cstring> #include <iostream> usi ...
- (十三)MySQL主从复制
(1)工作原理 (2)主从实现 1) 环境介绍 cat /etc/redhat-release CentOS Linux release 7.3.1611 (Core) MySQL版本:5.7 mys ...
- Jquery EasyUI选项卡-Tabs的使用方法
以下是easyUI的tabs的简单实用介绍. var e =$('#main').tabs('exists','accordion'); if(e==true){ $('#main').tabs(' ...
- JS—正则表达式
正则表达式的元字符是包含特殊含义的字符,它们有一些特殊的功能,可以控制匹配模式的方式,反斜杠后的元字符失去其特殊含义. 单个字符和数字 .表示匹配除换行符外的单个字符,两个.就表示匹配两个字符 var ...