「C Sharpとデータベース - 結果の取得」の版間の差分

提供:MochiuWiki : SUSE, EC, PCB
ナビゲーションに移動 検索に移動
(Wiki がページ「SQL Serverの実行結果を取得する(C Sharp)」を「C Sharpとデータベース - 結果の取得」に、リダイレクトを残さずに移動しました)
(文字列「<source lang」を「<syntaxhighlight lang」に置換)
11行目: 11行目:
DataSetを使用する方法もあるが、DataTableを取り出すためにワンクッション必要となるため、DataTableへ直接代入する方がよい。<br><br>
DataSetを使用する方法もあるが、DataTableを取り出すためにワンクッション必要となるため、DataTableへ直接代入する方がよい。<br><br>
一括でDataTableへ読み込む際は、DataAdapterを使用する。<br>
一括でDataTableへ読み込む際は、DataAdapterを使用する。<br>
  <source lang="c#">
  <syntaxhighlight lang="c#">
  using System;
  using System;
  using System.Configuration;
  using System.Configuration;
60行目: 60行目:
実装は面倒だが O/Rマッピングのようなことができる。<br><br>
実装は面倒だが O/Rマッピングのようなことができる。<br><br>
以下のサンプルコードにおけるUserModelはT_USERに対応する独自のクラスになる。<br>
以下のサンプルコードにおけるUserModelはT_USERに対応する独自のクラスになる。<br>
  <source lang="c#">
  <syntaxhighlight lang="c#">
  using System;
  using System;
  using System.Collections.Generic;
  using System.Collections.Generic;

2021年11月18日 (木) 06:12時点における版

概要

C#でSQL Serverに対してSELECT文を実行する時のサンプルコードを記載する。
ここでは、下記の2種類を例として取り上げる。

  • SELECT文の実行結果をDataTableを用いてまとめて読み込む方法
  • SELECT文の実行結果を1行ずつ読み込む方法


まとめて読み込む(DataTable)

DataTableへSELECT文の結果を一括で読み込む方法を説明する。この方法は単純で理解しやすい。
DataSetを使用する方法もあるが、DataTableを取り出すためにワンクッション必要となるため、DataTableへ直接代入する方がよい。

一括でDataTableへ読み込む際は、DataAdapterを使用する。

<syntaxhighlight lang="c#">
using System;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;

public DataTable GetData()
{
   var table = new DataTable();

   // 接続文字列の取得
   var connectionString = ConfigurationManager.ConnectionStrings["sqlsvr"].ConnectionString;

   using (var connection = new SqlConnection(connectionString))
   using (var command = connection.CreateCommand())
   {
       try
       {
           // データベースの接続開始
           connection.Open();

           // クエリの作成
           command.CommandText = @"SELECT count(*) FROM T_USER";

           // クエリの実行
           var adapter = new SqlDataAdapter(command);
           adapter.Fill(table);
       }
       catch (Exception exception)
       {
           Console.WriteLine(exception.Message);
           throw;
       }
       finally
       {   // データベースの接続終了
           connection.Close();
       }
   }

   return table;
}
</source>


1行ずつ読み込む(SqlDataReader)

SELECT文の結果を1行ずつ読み込む場合、DataReaderを使用する。
CommandのExecuteReader()メソッドを実行することで、DataReaderを取得し、1行ずつ読み込んで処理を行う。
実装は面倒だが O/Rマッピングのようなことができる。

以下のサンプルコードにおけるUserModelはT_USERに対応する独自のクラスになる。

<syntaxhighlight lang="c#">
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data.SqlClient;
using WebApplication1.Models;

public List<usermodel> GetData()
{
   var list = new List<usermodel>();

   // 接続文字列の取得
   var connectionString = ConfigurationManager.ConnectionStrings["sqlsvr"].ConnectionString;

   using (var connection = new SqlConnection(connectionString))
   using (var command = connection.CreateCommand())
   {
       try
       {
           // データベースの接続開始
           connection.Open();

           // クエリの作成
           command.CommandText = @"SELECT ID,PASSWORD,ROLE_NAME FROM T_USER";

           // クエリの実行
           using (var reader = command.ExecuteReader())
           {
               while (reader.Read() == true)
               {
                   list.Add(new UserModel()
                   {
                       Id = reader["ID"] as string,
                       Password = reader["PASSWORD"] as string,
                       RoleName = reader["ROLE_NAME"] as string
                   });
               }
           }
       }
       catch (Exception exception)
       {
           Console.WriteLine(exception.Message);
           throw;
       }
       finally
       {   // データベースの接続終了
           connection.Close();
       }
   }

   return list;
}
</source>