ホームページ > データベース > mysql チュートリアル > パラメーター化されたテーブル値パラメーターと C# を使用して SQL Server 2008 データベースに複数の行を効率的に挿入するにはどうすればよいですか?

パラメーター化されたテーブル値パラメーターと C# を使用して SQL Server 2008 データベースに複数の行を効率的に挿入するにはどうすればよいですか?

Patricia Arquette
リリース: 2025-01-12 08:42:45
オリジナル
210 人が閲覧しました

How Can I Efficiently Insert Multiple Rows into a SQL Server 2008 Database using Parameterized Table-Valued Parameters and C#?

C# とテーブル値パラメーターを使用した SQL Server 2008 への一括データ挿入の最適化

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# 実装

最後に、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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート