日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

SQL存储过程GET,POST 接口方法

發(fā)布時(shí)間:2023/12/31 综合教程 27 生活家
生活随笔 收集整理的這篇文章主要介紹了 SQL存储过程GET,POST 接口方法 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

數(shù)據(jù)庫(kù)版本:sql server 2016

準(zhǔn)備工作:先開啟Ole Automation Procedures,否則會(huì)報(bào)錯(cuò):SQL Server 阻止了對(duì)組件 'Ole Automation Procedures' 的 過程'sys.sp_OACreate' 的訪問

--開啟 Ole Automation Procedures
sp_configure 'show advanced options', 1;
GO
RECONFIGURE;
GO
sp_configure 'Ole Automation Procedures', 1;
GO
RECONFIGURE;
GO
EXEC sp_configure 'Ole Automation Procedures';
GO

--關(guān)閉 Ole Automation Procedures
sp_configure 'show advanced options', 1;
GO
RECONFIGURE;
GO
sp_configure 'Ole Automation Procedures', 1;
GO
RECONFIGURE;
GO
EXEC sp_configure 'Ole Automation Procedures';
GO

--關(guān)閉高級(jí)選項(xiàng)
sp_configure 'show advanced options', 0;
GO
RECONFIGURE;
GO

一,參數(shù)說明

sp_OACreate 創(chuàng)建 OLE 對(duì)象實(shí)例。
-->第一個(gè)參數(shù)為 OLE 對(duì)象的程序標(biāo)識(shí)符(ProgID)或類標(biāo)識(shí)符(CLSID)。
-->第二個(gè)參數(shù)為返回的對(duì)象令牌,必須是數(shù)據(jù)類型為 int 的局部變量,在后面的方法中都要用到對(duì)象令牌。輸出參數(shù),必須加 OUT 或 OUTPUT。
sp_OAMethod 調(diào)用 OLE 對(duì)象的方法。
-->第一個(gè)參數(shù)為對(duì)象令牌。
-->第二個(gè)參數(shù)為方法名稱。
-->第三個(gè)參數(shù)為方法的返回值,如果方法返回的是對(duì)象,則該參數(shù)類型為 int。輸出參數(shù),必須加 OUT 或 OUTPUT。
-->第四個(gè)及以后的參數(shù)為方法的參數(shù)值,如果方法的參數(shù)是輸出參數(shù),則要加上 OUT 或 OUTPUT。
-->sp_OAMethod也可用來獲取屬性值。
sp_OAGetErrorInfo 獲取 OLE 自動(dòng)化錯(cuò)誤信息。
-->第一個(gè)參數(shù)為對(duì)象令牌。
-->第二個(gè)參數(shù)為錯(cuò)誤信息的來源。輸出參數(shù),必須加 OUT 或 OUTPUT。
-->第三個(gè)參數(shù)為錯(cuò)誤的描述。輸出參數(shù),必須加 OUT 或 OUTPUT。
sp_OADestroy 釋放已創(chuàng)建的 OLE 對(duì)象。
-->第一個(gè)參數(shù)為對(duì)象令牌。
另外,sp_OAGetProperty 獲取 OLE 對(duì)象的屬性值,sp_OASetProperty 將 OLE 對(duì)象的屬性設(shè)置為新值,sp_OAStop 停止服務(wù)器范圍內(nèi)的 OLE 自動(dòng)化存儲(chǔ)過程執(zhí)行環(huán)境。這些都比較簡(jiǎn)單。
這七個(gè)存儲(chǔ)過程都有返回值,如果返回值是 0 表示成功,其它值表示失敗,示例中只對(duì) sp_OACreate 的返回值作了判斷。

二,GET方法參考

CREATE PROCEDURE [dbo].[get](  --創(chuàng)建存儲(chǔ)過程get 
    @URL varchar(500),  --輸入?yún)?shù)變量
    @ResponseText varchar(8000) OUTPUT  --返回參數(shù)
)
AS
BEGIN

Declare @Status as Int  --聲明對(duì)象類型為INT整數(shù)
--sp_OACreate  創(chuàng)建 OLE 對(duì)象實(shí)例, Msxml2.ServerXMLHTTP.3.0 返回的對(duì)象令牌,@Status:自定義對(duì)象名稱
--數(shù)據(jù)類型必須為 int 的局部變量,后面的方法中都要用到對(duì)象令牌。輸出參數(shù),必須加 OUT 或 OUTPUT。  
Exec sp_OACreate 'Msxml2.ServerXMLHTTP.3.0', @Status OUT;   --相當(dāng)于將Msxml2.ServerXMLHTTP.3.0賦值為@Status,@Status就算對(duì)象令牌
-->sp_OAMethod 一共有4個(gè)參數(shù),sp_OAMethod也可用來獲取屬性值。
Exec sp_OAMethod @Status, 'open', NULL, 'GET',@URL,'false'  --第一個(gè)參數(shù)為對(duì)象令牌。 
Exec sp_OAMethod @Status, 'setRequestHeader', NULL, 'Content-Type','application/json' --第二個(gè)參數(shù)為方法名稱。
Exec sp_OAMethod @Status, 'send', NULL, NULL  --第三個(gè)參數(shù)為方法的返回值,如果方法返回的是對(duì)象,則該參數(shù)類型為 int。輸出參數(shù),必須加 OUT 或 OUTPUT。
Exec sp_OAMethod @Status, 'responseText', @ResponseText OUTPUT  --第四個(gè)及以后的參數(shù)為方法的參數(shù)值,如果方法的參數(shù)是輸出參數(shù),則要加上 OUT 或 OUTPUT。
if @Status<>0
  begin
--sp_OAGetErrorInfo 獲取 OLE 自動(dòng)化錯(cuò)誤信息。
--第一個(gè)參數(shù)為對(duì)象令牌。
--第二個(gè)參數(shù)為錯(cuò)誤信息的來源。輸出參數(shù),必須加 OUT 或 OUTPUT。
--第三個(gè)參數(shù)為錯(cuò)誤的描述。輸出參數(shù),必須加 OUT 或 OUTPUT。
    EXEC sp_OAGetErrorInfo @Status  --sp_OAGetErrorInfo 獲取 OLE 自動(dòng)化錯(cuò)誤信息。

  end
Exec sp_OADestroy @Status  --sp_OADestroy 釋放已創(chuàng)建的 OLE 對(duì)象。
END

三,POST方法參考

CREATE PROCEDURE [dbo].[sp_http_post](
    @URL varchar(500),  --請(qǐng)求地址
    @Data varchar(8000), --請(qǐng)求參數(shù)
    @ResponseText varchar(8000) OUTPUT
)
AS
BEGIN

Declare @Status as Int   
Exec sp_OACreate 'Msxml2.ServerXMLHTTP.3.0', @Status OUT;
Exec sp_OAMethod @Status, 'open', NULL, 'POST',@URL,'false'
Exec sp_OAMethod @Status, 'setRequestHeader', NULL, 'Content-Type','application/json'
Exec sp_OAMethod @Status, 'send', NULL, @Data
Exec sp_OAMethod @Status, 'responseText', @ResponseText OUTPUT
if @Status<>0
  begin
    EXEC sp_OAGetErrorInfo @Status
  end
Exec sp_OADestroy @Status
END

參考地址:https://www.cnblogs.com/icyhoo/p/12942833.html

總結(jié)

以上是生活随笔為你收集整理的SQL存储过程GET,POST 接口方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。