簡體   English   中英

T-SQL…表示法

[英]T-SQL … Notation

在研究優化SQL Server批量更新的方法時,我遇到了以下查詢,該查詢可以正常運行,但是在理解以下c#代碼段中“ ...”表示法的工作方式時遇到了困難:

command.CommandText = "CREATE TABLE #TmpTable(...)";
command.ExecuteNonQuery();

command.CommandText = "UPDATE T SET ... FROM " + tableName + " T INNER JOIN #TmpTable Temp ON ...; DROP TABLE #TmpTable;"
command.ExecuteNonQuery();

代碼中存在一個錯誤,因此直接更新了目標表,而不是先寫入臨時表。 引用的代碼使用省略號(...)作為占位符,但由於某種原因,我的代碼未能在應有的位置拋出異常。 更正后的代碼段應如下所示:

command.CommandText = "CREATE TABLE #TmpTable(Id int, x int)";
command.ExecuteNonQuery();

// Insert updated rows read from 'tableName' into #TmpTable

command.CommandText = "UPDATE T SET T.x = Temp.x FROM " + tableName + " T INNER JOIN #TmpTable Temp ON T.Id = Temp.Id; DROP TABLE #TmpTable;"
command.ExecuteNonQuery();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM