汎用的なコードでデータベースアクセス(パラメータ)

C#

[この記事は18年前に書かれました]

汎用的なコードで、動的なパラメータのあるデータベースアクセスを行うにはDbParameterクラスを使用します。 実行するクエリのパラメータ部にはプレイスホルダを指定しておきます。

このフォーマットは、汎用的なクラスであるDbParameterを使用しても以下のようにOracleとSQL Server で切り替える必要があります。

Oracleの場合「:パラメータ名」(コロンを指定)
SQL Serverの場合「@パラメータ名」(アットマークを指定)

using System.Configuration;
using System.Data.Common;
...

ConnectionStringSettings setting = System.Configuration.ConfigurationManager.ConnectionStrings["OracleTest"];
DbProviderFactory factory = DbProviderFactories.GetFactory(setting.ProviderName);

using (DbConnection con = factory.CreateConnection())
{
  con.ConnectionString = setting.ConnectionString;
  con.Open();

  try
  {
    using (DbCommand cmd = con.CreateCommand())
    {
      // クエリ文字列(プレイスホルダ指定)
      cmd.CommandText = "select column1, column2 from test where column1 = :column1 and column2 = :column2";

      // パラメータの生成
      DbParameter para1 = cmd.CreateParameter();
      para1.ParameterName = "column1";
      para1.Value = "103";
      cmd.Parameters.Add(para1);

      DbParameter para2= cmd.CreateParameter();
      para2.ParameterName = "column2";
      para2.Value = "test";
      cmd.Parameters.Add(para2);

      using (DbDataReader reader = cmd.ExecuteReader())
      {
        while (reader.Read())
        {
          Console.WriteLine(reader["column1"]);
          Console.WriteLine(reader["column2"]);
        }
      }
    }
  }
  finally
  {
    if (con != null)
    {
      con.Close();
    }
  }
}

出力:
103
test

パラメータの型は、設定された値から推測されますが、明示的に指定する場合は、DbParameter.DbTypeを指定します。

  (※).NET Framework version 2.0新機能

コメント

タイトルとURLをコピーしました