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 程序集删除重新设定才是修改后效果。

相关推荐
我爱夜来香A7 小时前
Sql进阶:字段中包含CSV,如何通过Sql解析CSV成多行多列?
数据库·sql
小吕学编程8 小时前
开发中SQL积累
java·数据库·sql
幽兰的天空8 小时前
高级 SQL 技巧:提升数据查询与管理效率
sql
OceanBase数据库官方博客8 小时前
ODC 如何精确呈现SQL耗时 | OceanBase 开发者工具解析
sql·oceanbase·分布式数据库·开发者·生态工具
Suckerbin10 小时前
DVWA靶场通关——SQL Injection篇
sql·网络安全
.生产的驴10 小时前
Docker 部署Nacos 单机部署 MYSQL数据持久化
android·运维·spring boot·sql·mysql·docker·容器
猫爪笔记10 小时前
MySQL数据库:SQL语言入门 【2】(学习笔记)
数据库·笔记·sql·学习·mysql
DC_BLOG15 小时前
Mysql前言
数据库·sql·mysql
Mephisto.java16 小时前
【大数据学习 | HBASE高级】hbase-phoenix 与二次索引应用
大数据·sql·oracle·sqlite·json·hbase
Mephisto.java16 小时前
【大数据学习 | flume】flume之常见的source组件
大数据·sql·oracle·json·database·flume