MSSQL 程序集使用方法

1.C# 写一个程序

1.1新建一个项目【类库【.Net FrameWork】

1.2编写代码

删除

namespace ApiSQLClass

{

}

代码如下:【具体调用API模式根据具体编写】

cs 复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.SqlServer.Server;


    public class ApiSQLHelper
    { 
    [SqlFunction]
    public static string CallAPI(string apiMethod, string apiURL, string apiPMS)
    {
        return apiPMS;
    }
    }

2.数据库设定

2.1数据库设定

sql 复制代码
Use master 
exec sp_configure 'show advanced options', '1';
go

reconfigure;
go

exec sp_configure 'clr enabled', '1'
go

reconfigure;
exec sp_configure 'show advanced options', '1';
go 
Use [DB] --DB 具体为需要使用的数据库

ALTER DATABASE [DB]  SET TRUSTWORTHY on;
go

2.2程序集设定

1.选择需要设定数据库后按下步骤进行

3.SQL使用

3.1函数代码

sql 复制代码
create function [dbo].[fn_CallAPI]
(
	@apiMethod nvarchar(max)		--Post/Get
	, @apiURL nvarchar(max)		--API地址		
	 
	, @apiPMS nvarchar(max)		--JSON格式的参数
)
RETURNS [nvarchar](max) WITH EXECUTE AS CALLER
AS 
EXTERNAL NAME [ApiSQLClass].[ApiSQLHelper].[CallAPI]
 

3.2测试效果

sql 复制代码
declare @apiPMS nvarchar(max);
--set @pms='{"Username":"Test","Password":"Test"}'   --参数
set @apiPMS = (select 'admin' as 'User_id', '123' as 'PSW' for json path, without_array_wrapper);
select [dbo].[fn_CallAPI]( 'POST', 'apits',  @apiPMS)
 

结果集:{"User_id":"admin","PSW":"123"}

4.总结

4.1:需要删除:namespace,否则在创建函数时候报错

4.2:新建;类库【.Net FrameWork】,使用其他类型都未成功

4.3:.Net语句修改重新生成编译,需要把SQL 程序集删除重新设定才是修改后效果。

相关推荐
ha_lydms6 分钟前
4、Spark 函数_m/n/o/p/q/r
大数据·数据库·python·sql·spark·数据处理·dataworks
lkbhua莱克瓦2441 分钟前
基础-约束
android·开发语言·数据库·笔记·sql·mysql·约束
falldeep44 分钟前
LeetCode高频SQL50题总结
数据结构·数据库·sql·算法·leetcode·职场和发展
G皮T1 小时前
【Elasticsearch】查询性能调优(二):SQL LIMIT 和 terminate_after 对比
大数据·sql·elasticsearch·搜索引擎·全文检索·es·opensearch
hopsky10 小时前
ShardingSphere功能简介
数据库·sql
武昌库里写JAVA10 小时前
iview-CRUD模板
vue.js·spring boot·sql·layui·课程设计
男孩李15 小时前
linux下如何执行postgres数据库的sql文件
数据库·sql·postgresql
zwjapple15 小时前
MySQL SQL 面试核心考点与注意事项总结
数据库·sql·mysql
05大叔15 小时前
Spring Day02
数据库·sql·spring
小韩博18 小时前
小迪笔记45课之-PHP应用&SQL二次注入&堆叠执行&DNS带外&功能点&黑白盒条件
笔记·sql·网络安全·php