SQL Server 2008 以降の動的 SQL へのテーブル変数の統合
SQL Server 2008 以降のバージョンで動的 SQL クエリを構築するには、多くの場合、テーブル変数を組み込む必要があります。 ただし、これらを直接含めると、「宣言されていないテーブル変数」エラーが頻繁に発生します。
解決策は、テーブル値パラメーターを活用することにあります。 これらのパラメータを使用すると、ベース テーブルを変更せずにテーブル変数を動的 SQL に渡すことができます。
一般的な問題を調べてみましょう:
<code class="language-sql">set @col_name = 'Assoc_Item_' + Convert(nvarchar(2), @curr_row1); set @sqlstat = 'update @RelPro set ' + @col_name + ' = (Select relsku From @TSku Where tid = ' + Convert(nvarchar(2), @curr_row1) + ') Where RowID = ' + Convert(nvarchar(2), @curr_row); Exec(@sqlstat);</code>
@RelPro
と @TSku
は動的 SQL コンテキスト内で認識されないため、このコードは失敗します。 @TSku
を正しく渡すには、テーブル値パラメーターを利用します:
<code class="language-sql">EXEC sp_executesql N'SELECT * FROM @T', N'@T MyTable READONLY', @T=@TSku;</code>
ここでは、@TSku
が読み取り専用パラメータ (READONLY
) として sp_executesql
に渡されます。 @T
パラメータは、動的 SQL ステートメント内のプレースホルダーとして機能します。 この方法では、テーブル変数が動的クエリにきれいに統合され、宣言エラーが防止され、スムーズな実行が保証されます。 このアプローチは、テーブル変数を含む動的 SQL クエリを管理する堅牢かつ効率的な方法を提供します。
以上がSQL Server 2008 でテーブル変数を SQL ステートメントに動的に挿入するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。