第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在存儲過程參數(shù)列表中使用表達式的結(jié)果(例如,函數(shù)調(diào)用)?

在存儲過程參數(shù)列表中使用表達式的結(jié)果(例如,函數(shù)調(diào)用)?

汪汪一只貓 2019-11-04 09:29:42
我試圖編寫一個存儲過程來協(xié)助我們的數(shù)據(jù)庫開發(fā),但是在使用它時遇到了一些麻煩。例如:DECLARE @pID int;SET @pID = 1;EXEC WriteLog 'Component', 'Source', 'Could not find given id: ' + CAST(@pID AS varchar);這將產(chǎn)生錯誤(在SQL Server 2005上):消息102,級別15,狀態(tài)1,第4行'+'附近的語法不正確。有人可以向我解釋為什么我的語法不正確以及解決此問題的正確方法嗎?
查看完整描述

3 回答

?
慕碼人8056858

TA貢獻1803條經(jīng)驗 獲得超6個贊

您需要使用一個中間變量。盡管SQL Server已經(jīng)出現(xiàn)在TODO列表中有幾年了,但它本身在參數(shù)列表中不支持這種操作?。ㄕ垍㈤啞?連接項目:使用標(biāo)量函數(shù)作為存儲過程參數(shù)”)


的語法EXEC是


[ { EXEC | EXECUTE } ]

    { 

      [ @return_status = ]

      { module_name [ ;number ] | @module_name_var } 

        [ [ @parameter = ] { value 

                           | @variable [ OUTPUT ] 

                           | [ DEFAULT ] 

                           }

        ]

      [ ,...n ]

      [ WITH <execute_option> [ ,...n ] ]

    }

[;]

該文檔目前尚不清楚可接受格式,value但似乎僅僅是“簡單”表達式,例如文字值或帶@@前綴的系統(tǒng)函數(shù)(例如@@IDENTITY)。SCOPE_IDENTITY()不允許使用其他系統(tǒng)功能(甚至不允許使用不需要括號的功能CURRENT_TIMESTAMP)。


所以暫時您需要使用如下語法


DECLARE @pID INT;


SET @pID = 1;


/*If 2008+ for previous versions this needs to be two separate statements*/

DECLARE @string VARCHAR(50) = 'Could not find given id: ' + CAST(@pID AS VARCHAR(11))


EXEC WriteLog

  'Component',

  'Source',

  @string 


查看完整回答
反對 回復(fù) 2019-11-04
?
哆啦的時光機

TA貢獻1779條經(jīng)驗 獲得超6個贊

您不能對存儲過程的參數(shù)進行操作。您應(yīng)該在另一個變量上分配該值,然后將其傳遞給SP。


DECLARE @pID int, @nameId VARCHAR(100);

SET @pID = 1;

SET @nameId = 'Could not find given id: ' + CAST(@pID AS varchar);


EXEC WriteLog 'Component', 'Source', @nameId


查看完整回答
反對 回復(fù) 2019-11-04
  • 3 回答
  • 0 關(guān)注
  • 703 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號