.NETエンジニア・プログラマ向けの技術情報・業界ニュースをお届けします。

  1. FEnet.NETナビ
  2. .NETコラム
  3. プログラミング言語
  4. C#
  5. C#でDataTableからデータを抽出。LINQが高速でおすすめ!

C#でDataTableからデータを抽出。LINQが高速でおすすめ!

  • C#
  • LINQ
  • プログラミング言語
公開日時:   更新日時:
C#でDataTableからデータを抽出。LINQが高速でおすすめ!
この記事でわかること
    基本情報技術者試験の試験対策はこちら>>

    C#のアプリケーション開発で、データベースから取得したデータや、更新するためのデータをメモリ上に一時的に保管しておく際によく利用されるのが、DataTableです。そしてDataTableから、より高速にデータを取得するにはLINQ(統合言語クエリ)と併用することも多いでしょう。ここでは、LINQを駆使したDataTableの扱い方について確認していきます。

    プログラマー
    DataTableでもLINQって使えるのですね。やっぱりLINQを使ってプログラミングは行うべきでしょうか。
    プロジェクト
    マネージャー
    そうですね。何よりLINQは処理速度が高速です。ユーザーにとって処理速度が遅いのは、ストレスがたまる一因となりますので、処理速度は重視するべき点だといえます。

    実行環境
    ・Visual Studio Community 2017

    DataSetクラスとDataTableクラス

    DataTableの基本的な事柄から解説していきます。

    まずDataSetクラスとは、メモリにデータベースを構成するクラスのことを指します。

    一般的にひとつのデータベースの中には複数のテーブルが存在しているかと思います。DataSetクラス(データベース)では、データベースと同じように複数のテーブルを持つことが可能です。このDataSetクラス内にある複数のテーブルがDataTableクラスとなります。

    DataTableクラス(テーブル)の中にはさらに、DataColumnクラス(列・カラム)があり、DataRowクラス(行・レコード)がそれぞれ存在してきます。これらのクラスは、C#サイドでDataTableを活用してデータを扱うにはひとつとして欠かすことができないクラス群です。

    LINQのWhereで抽出する方法

    DataTableとLINQは併用できないと思われている方も多いと思いますが、実はLINQを駆使してDataTableからデータを取得することは可能です。その際にキーワードとなるのが「AsEnumerable()」です。これがなければDataTableからLINQを使って抽出することはできません。

    LINQを使うメリットは、従来のDataTable.Select()メソッドより格段に処理速度が上がることです。デメリットを挙げるとするならば、LINQの知識が必要となるため、C#初学者の方には少しハードルが高くなる点でしょう。

    次に、LINQのWhereを利用してデータを抽出するサンプルコードを確認します。

    ボタン押下でラベルに処理時間が反映されます。

    実行前
    LINQ実行前

    実行後
    LINQ実行結果

    Selectメソッドを使う方法

    以前からC#またはVB.NETに携わっている方でしたら、DataTable.Select()メソッドを利用してデータを取得することもあります。

    LINQに比べてコーディングが簡単というメリットがある一方、処理速度が遅いというデメリットがあります。データ件数が10件、100件程度であれば時間差はそれほどないですが、例えば100万件のデータを一度で扱うとなると、かなりの差異が発生します。

    実行後
    Selectメソッド実行結果

    処理時間の比較

    LINQ使用 00:00:01.2172834
    DataTable.Select()メソッド使用 00:00:12.6796385

    処理時間に差異があるのがお分かりいただけたかと思います。その差は約10倍程度の開きがあります。こうしたからLINQを使ってコーディングすることをおすすめします。

    プログラマー
    処理速度が全然違いますね。これはLINQを使うべきでした!もっとLINQの勉強に励みます。
    プロジェクト
    マネージャー
    LINQは積極的に使うべき命令のひとつです!新人の頃はプログラミングを行うだけでも精一杯だと思いますが、処理速度まで考慮できて一流のプログラマーです。DataTableを使ってプログラミングを行う際には、LINQと併用して活用していきましょう。

    DataTableにはLINQを活用しましょう

    C#で開発するアプリケーションのデータアクセス技術は現在、Entity Frameworkがどちらかというと主流です。しかし、既存のプログラムではDataTableの活用例が多いかと思います。ユーザーからレスポンス改善依頼が挙がった場合には、DataTable.Select()メソッドからLINQに切り替える修正を行い、処理速度をより高速にして対応していきましょう。

    >>>C#の案件を探すならFEnet .NET Navi

    FEnet.NETナビ・.NETコラムは株式会社オープンアップシステムが運営しています。
    株式会社オープンアップシステムロゴ

    株式会社オープンアップシステムはこんな会社です

    秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
    数多くのエンジニアが集まります。

    秋葉原オフィスイメージ
    • スマホアプリから業務系システムまで

      スマホアプリから業務系システムまで

      スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。

    • 充実した研修制度

      充実した研修制度

      毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。

    • 資格取得を応援

      資格取得を応援

      スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。

    • 東証プライム上場企業グループ

      東証プライム上場企業グループ

      オープンアップシステムは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。

      安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。

    株式会社オープンアップシステムに興味を持った方へ

    株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。

    年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
    まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。

    株式会社オープンアップシステムへのご応募はこちら↓
    株式会社オープンアップシステムへのご応募はこちら↓

    C#新着案件New Job