動的SQL(ms sql 2005)を使用した2つのストアドプロシージャがあります。まず、一時テーブル (##Table) を作成し、データを入力します。2 番目の手順では、最初の手順で作成された一時テーブルからデータを選択します。
最初のsp:
set @cmd = 'create table ' + @tableName +
'(ORDERS_DT_ID int' +
...
',WAREHOUSE_RESULT numeric(15, 3)) ' +
' insert into ' + @tableName + ' ( ORDERS_DT_ID, ... WAREHOUSE_RESULT )' +
' select ro.ORDERS_DT_ID, ... ro.WAREHOUSE_RESULT ' +
' from WH_REMAINS_BY_ORDER_FN ( ' + cast(@orderId as varchar(10)) + ' ) as ro '
exec (@cmd)
2 番目の sp (例):
set @cmd = 'select r.ORDERS_DT_ID, ... r.WAREHOUSE_RESULT' +
' from ' + @tableName + ' as r'
exec (@cmd)
where @tableName - sp の入力パラメーター ( = '##Table' など)
私はasp.net mvcアプリケーションからその手順を使用します。最初のプロシージャを呼び出し、MSSMS から一時テーブルをチェックし (テーブルが存在する)、アプリケーションがブレークポイントで停止し (2 番目の SP の前)、次に 2 番目のプロシージャを呼び出し、テーブルが存在しません (ただし、1 番目と 2 番目のプロシージャの間にテーブルが存在します)。
var result = dataContext.firstSP(table, orderId).FirstOrDefault(); // create temp table and fill data (+ return status)
var data = dataContext.secondSP( table, orderId ).AsQueryable(); // before execute we have temp table (check from MSSMS) and we have error after execute that code.
2 番目の手順で一時テーブルを確認すると、テーブルが存在しないことがわかります。
if object_id ( N'tempdb.dbo.' + ltrim(@tableName) ) is null
begin
exec dbo.firstSP @tableName, @orderId
end
2 番目の SP を実行すると、最初の SP の一時テーブルが削除されるのはなぜですか?