SQL Server 2008 データベースに多数の行を個別に挿入すると、パフォーマンスに大きな影響を与える可能性があります。 この記事では、パラメーター化されたテーブル値パラメーターと C# を使用したより効率的なアプローチを示します。
まず、ターゲット テーブルの構造をミラーリングするユーザー定義のテーブル タイプを SQL Server に作成します。
<code class="language-sql">CREATE TYPE MyTableType AS TABLE ( Col1 int, Col2 varchar(20) ) GO</code>
次に、このテーブル タイプを入力として受け入れ、一括挿入を実行するストアド プロシージャを作成します。
<code class="language-sql">CREATE PROCEDURE MyProcedure ( @MyTable dbo.MyTableType READONLY -- Readonly is crucial for table-valued parameters ) AS BEGIN INSERT INTO MyTable (Col1, Col2) SELECT Col1, Col2 FROM @MyTable; END; GO</code>
最後に、C# を使用して DataTable
を設定し、それをテーブル値パラメーターとしてストアド プロシージャに渡します。
<code class="language-csharp">DataTable dt = new DataTable(); dt.Columns.Add("Col1", typeof(int)); dt.Columns.Add("Col2", typeof(string)); // Populate the DataTable with your data using (SqlConnection con = new SqlConnection("ConnectionString")) { using (SqlCommand cmd = new SqlCommand("MyProcedure", con)) { cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.AddWithValue("@MyTable", dt); // AddWith Value handles SqlDbType automatically con.Open(); cmd.ExecuteNonQuery(); } }</code>
この方法では、テーブル値パラメーターの機能を利用して、C# アプリケーションから SQL Server 2008 データベースに複数の行を挿入する効率が大幅に向上します。 このアプローチは、個別の行の挿入と比較して優れたパフォーマンスを提供します。
以上がパラメーター化されたテーブル値パラメーターと C# を使用して SQL Server 2008 データベースに複数の行を効率的に挿入するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。