SQLserver通過CLR調用TCP接口

一、SQLserver啟用CLR

  • 查看是否開啟CRL,如果run_value=1,則表示開啟
EXEC sp_configure 'clr enabled';
GO
RECONFIGURE;
GO

在這里插入圖片描述

  • 如果未啟用,則執行如下命令啟用CLR
sp_configure 'clr enabled', 1;
GO
RECONFIGURE;
GO

二、創建 CLR 程序集

  • 創建新項目
    打開 Visual Studio,創建一個新的類庫項目,命名為TcpClientWrapper,目標框架選擇 .NET Framework 3.5。
    在這里插入圖片描述
    在這里插入圖片描述

  • 編寫 TCP 通信代碼
    在Class1.cs文件中添加如下代碼

using System;
using System.Data.SqlTypes;
using System.IO;
using System.Net.Sockets;
using Microsoft.SqlServer.Server;public class TcpClientWrapper
{private static TcpClient client;[SqlFunction]public static SqlString CallTcpService(SqlString host, SqlInt32 port, SqlString message){try{if (client == null || !client.Connected){client = new TcpClient(host.Value, port.Value);}using (NetworkStream stream = client.GetStream()){using (var writer = new StreamWriter(stream))using (var reader = new StreamReader(stream)){// Send the message to the TCP server.writer.Write(message.Value);writer.Flush();// Read the response from the TCP server.int response = reader.Read();char character = Convert.ToChar(response);//string response = reader.ReadToEnd();return new SqlString(response + "_" + character);}}}catch (Exception ex){return new SqlString("Error: " + ex.Message);}}
}
  • 編譯項目
    會在 {項目路徑}/bin/debug 下生成DLL文件,
    在這里插入圖片描述
    在這里插入圖片描述

三、部署程序集到SQLserver

  • 將生成的dll文件上傳到SQLserver服務器上,記錄文件路徑
  • 執行以下命令將程序集加載到 SQL Server
-- 因為程序中使用了靜態成員變量,所以需要UNSAFE模式,否則會報錯,建議使用SAFE、EXTERNAL_ACCESS模式
CREATE ASSEMBLY TcpClientWrapper FROM 'C:\test\TcpClientWrapper.dll' WITH PERMISSION_SET = UNSAFE;-- 刪除 ASSEMBLY 
DROP ASSEMBLY TcpClientWrapper;
  • 創建函數以調用程序集中的方法
CREATE FUNCTION dbo.CallTcpService(@host NVARCHAR(255), @port INT, @message NVARCHAR(MAX))
RETURNS NVARCHAR(MAX)
AS EXTERNAL NAME TcpClientWrapper.[TcpClientWrapper].CallTcpService;

四、調用TCP接口

DECLARE @response NVARCHAR(MAX);
SET @response = dbo.CallTcpService('127.0.0.1', 8899, '好');
PRINT @response;

數據庫端:
在這里插入圖片描述
服務端:
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/23199.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/23199.shtml
英文地址,請注明出處:http://en.pswp.cn/web/23199.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Vue3:eachars 折線圖 數據不聯動 和 tooltip: trigger: ‘axis‘ 不生效,不提示數據

問題1: 點擊折線圖的頭部數據(Email、UnionAds等) 下面數據線不聯動問題 問題2:下圖是沒有提示數據的Demo 這是echars官網的提示數據圖 3.解決辦法 (1)檢查是否設置:trigger:axi…

spring 使用多線程,保證事務一致性

1、背景 最近接受到接口優化的任務,查看代碼邏輯后發現在批量處理數據耗時長,想到使用多線程處理批量數據,又要保持原來的事務一致性。 2、實現方法 (1)、創建多線程事務管理 Component Slf4j public class MultiT…

海外BGP服務器有什么功能?

當企業選擇海外的BGP服務器進行租用時,能夠實現哪些功能呢? 當企業擁有海外的BGP服務器時,可以改善網站的訪問速度,對于面向全球用戶的網站或者是應用來說,能夠通過在不同區域所部署的BGP服務器,用戶可以根…

【Unity Shader入門精要 第13章】使用深度和法線紋理(一)

1. 原理 深度紋理的本質是一張RenderTexture,只不過其中記錄的不是顏色值,而是一個深度值 這些深度值來自于頂點在空間變換后得到的歸一化設備坐標(NDC)的Z值 由于NDC坐標的分量取值范圍在[-1, 1]之間,要使顏色值能…

基于pytorch的車牌識別

🍨 本文為🔗365天深度學習訓練營 中的學習記錄博客🍖 原作者:K同學啊 一、導入數據 from torchvision.transforms import transforms from torch.utils.data import DataLoader from torchvision import datase…

RSA 非對稱加密:

非對稱加密 RSA 擁有兩個密鑰, 分別為 公鑰 和 私鑰, 服務器端擁有公鑰和私鑰, 二客戶端,只有公鑰, 這個公鑰可以隨便傳,即使被截獲也沒有關系, 加密使用公鑰, 而解密,…

Mysql時間操作

一、MySql時間戳轉換 select unix_timestamp(); #獲取時間戳格式時間 select FROM_UNIXTIME(1717399499); #將時間戳轉換為普通格式時間二、Mysql時間相加減結果轉換為秒 方法1:time_to_sec(timediff(endTime, startTime)) SELECTDISTINCT(column1),min(last_mo…

在Jenkins 中使用 NVM 管理 Node.js 部署項目的自動化腳本

在Jenkins 中使用 NVM 管理 Node.js 部署項目的自動化腳本 人生旅途,總有人不斷地走來,有人不斷地離去。當新名字變成老名字,當老的名字漸漸模糊,又是一個故事的結束和另一個故事的開始。 在現代軟件開發中,持續集成/持…

容器化實踐:DevOps環境下的容器交付流程

DevOps的興起是為了應對市場和消費者對技術應用的不斷增長的需求。它的目標是構建一個更快的開發環境,同時保持軟件的高質量標準。DevOps還致力于在敏捷開發周期中提升軟件的整體品質。這一目標的實現依賴于多種技術、平臺和工具的綜合運用。 結合容器化技術與DevO…

深入理解mysql中的各種超時屬性

1. 前言 connectTimeout: 連接超時 loginTimeout: 登錄超時 socketTimeout: Socket網絡超時,即讀超時 queryTimeout: sql執行超時 transactionTimeout:spring事務超時 innodb_lock_wait_timeout:innodb鎖等待超時 wait_timeout:非交互式連接關閉前的等待時間 inter…

uniapp小程序多線程 Worker 實戰【2024】

需求 最近遇到個小程序異步解碼的需求,采用了WebAssembly,涉及大量的計算。由于小程序的雙線程模型只有一個線程處理數據,因此智能尋求其它的解決方案。查看小程序的文檔,發現小程序還提供一個異步線程的Worker方案,可…

代碼隨想錄算法訓練營第25天|回溯

回溯part02 216. 組合總和 III /*** param {number} k* param {number} n* return {number[][]}*/ var combinationSum3 function(k, n) {// k個數字相加為n// 只能使用1-9// 每個數字只能使用一次// 不能重復 如 1 2 4 、 4 1 2 不可以let res [];backtracking(k, n, [], …

聯想Y410P跑大模型

安裝vs 2017 查看GPU版本 查看支持哪個版本的cuda windows cuda更新教程_cuda 12.0-CSDN博客 下載并安裝cuda tookit 10.1 CUDA Toolkit 10.1 Update 2 Archive | NVIDIA Developer 找到下載的文件,安裝 參考安裝鏈接 Win10 Vs2017 CUDA10.1安裝(避坑…

Due to a bug fix in https://github.com/huggingface/transformers/pull/28687

錯誤: Due to a bug fix in https://github.com/huggingface/transformers/pull/28687 transcription using a multilingual Whisper will default to language detection followed by transcription instead of translation to English.This might be a breaking …

InnoDB存儲引擎非常重要的一個機制--MVCC(多版本并發控制)

Mysql是如何實現隔離性的?(鎖MVCC) 隔離性是指一個事務內部的操作以及操作的數據對正在進行的其他事務是隔離的,并發執行的各個事務之間不能相互干擾。隔離性可以防止多個事務并發執行時,可能存在交叉執行導致數據的不…

安全U盤和普通U盤有什么區別?

安全U盤(也稱為加密U盤或安全閃存驅動器)與普通U盤肯定是有一些區別的,從字面意思上來看,就能看出,安全U盤是能夠保護文件數據安全性的,普通U盤沒這一些功能的,可隨意拷貝文件,不防盜…

面試4:c++(數位物聯)

1.const 關健字的作用 定義常量,防止變量被意外修改,增強程序的可讀性和維護性。 可以用于指針,聲明指向常量的指針或常量指針。 2.static關健字的作用 (1)在函數內,用于修飾局部變量,使其生命周期延長到整個程序運行期…

mybatisplus多數據源內置方法報Invalid bound statement (not found)

在用mybatis-plus多數據源時用mapper內置的 selectList(queryWrapper) 查詢數據報org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): 問題是在配置多數據源時用的是SqlSessionFactoryBean,改為MybatisSqlSessionFactoryBean即可…

Python怎么逐行處理文件:深度解析與實用技巧

Python怎么逐行處理文件:深度解析與實用技巧 在Python中,逐行處理文件是一項常見且重要的任務。無論是讀取大型日志文件、分析文本數據還是處理配置文件,逐行讀取都能幫助我們更有效地管理內存并提高處理速度。本文將詳細介紹Python中逐行處…

一文了解UVLED線光源的應用

在機器視覺系統中,光源作為不可或缺的一部分,能夠提高目標成像效果,增強檢測效果。光源的選擇至關重要,選到不合適的會影響成像及檢測效果。針對不同的檢測對象,不同的形狀光源應運而生。我們來看看最UVLED線光源。 下面以CCS的光…