SQL server 動態SQL對變數講行賦值

來源:互聯網
上載者:User

執行如下SQL

declare @t int

exec('set @t=1')

print(@t)

報如下錯誤!

伺服器: 訊息 137,層級 15,狀態 2,行 1

必須聲明變數
'@t'

 

 實際就是變數與動態語句不能共用,

那麼換成這樣就行,
declare @t int

set @t=1

print(@t)


exec('declare @t int;

set @t=1;

print(@t)')


但是有時候你一定要,變數與動態SQL結合起來。

比如,你在預存程序中定義一個輸出參數,◎COUNT int output

而你在獲得這個值的最好的方法就是動態SQL,那麼有什麼好的方式嗎?

那就要用到系統預存程序,sp_executesql

 

         declare @sql2 nvarchar(500)

           set @sql2 = 'select @COUNT = count(distinct('+@groupby+')) from TG_ENTRY where '+@sqlWhere

    execute sp_executesql 

          @sql2,

          N'@COUNT int output',

          @TOTAL_COUNT output

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.