SQL存储过程GET,POST 接口方法
數(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)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: nginx日志中添加请求的respons
- 下一篇: 微信小程序cavas画图并保存