|
.NET TIPS [ADO.NET]データテーブル(DataTable)内のレコードをソートするには?デジタルアドバンテージ 遠藤 孝信2005/10/14 |
![]() |
|
|
|
データテーブル*は、メモリ上において(主にデータベースの)テーブルを表すためのオブジェクトである。一般的にデータテーブルは、データベースから取得したレコード(行データ)を保持するのに使われる。
データテーブルのレコードをソート(並べ替え)したい場合には、データベースからレコードを取得するときに発行するSQL文(SELECT文)でソート条件を指定すれば、データテーブル内のレコードはソートされた状態となる。
しかし、複数の検索結果を1つのデータテーブルにマージした場合や、データベース以外のデータソースからデータテーブルを作成した場合などにもレコードをソートしたいなら、データテーブル上でソートを行う必要がある。本稿ではこの方法について解説する。
| * DataTableクラス(System.Data名前空間)のオブジェクト。詳細については「ADO.NET基礎講座:第4回 データセットを使ったデータベース・アクセス」を参照。 |
データビューを利用したデータテーブルのソート
データテーブル自体にはソート機能が用意されていない。このためデータテーブルをソートするには、まず空のデータテーブルを作成し、そこにソート済みのレコードを順に挿入していくことになる。
レコードのソートについては、データビュー(DataViewクラス(System.Data名前空間)のオブジェクト)を利用して、ソートされたデータテーブルの「ビュー」を作成すればよい。
具体的には次図のような手順によりデータテーブルをソートすることができる。
![]() |
|||||||||
| データテーブルのソート手順 | |||||||||
|
のデータテーブルのコピーについては、DataTableクラスのCloneメソッドにより行える。このメソッドは、新しいデータテーブルのインスタンスを作成し、元のデータテーブルの構造のみをコピーする。
また、
のレコードのコピーについては、DataTableクラスのImportRowメソッドが利用できる。データビューの各レコードは、レコードのビューであるDataRowViewオブジェクト(System.Data名前空間)として扱われるが、そのRowプロパティにより、元のデータテーブルにあるレコードであるDataRowオブジェクト(System.Data名前空間)にアクセスできる。
データテーブルをソートするサンプル・プログラム
次のサンプル・プログラムは実際にデータテーブルを作成し、ソートを行っている例だ。
このプログラムでは、@ITのRSS情報を読み取ってデータテーブルを作成している。このRSS情報の読み取りについては「TIPS:[ASP.NET]DataGridコントロールでデータセットを表示するには?」の後半部分で解説しているので、そちらを参照していただきたい。
|
|
| データテーブルをソートするC#のサンプル・プログラム(dtsort.cs) | |
|
|
| データテーブルをソートするVB.NETのサンプル・プログラム(dtsort.vb) | |
プログラムでは、元のデータテーブル、Cloneメソッドにより作成したデータテーブル、そしてソートされたレコードを含むデータテーブルの内容を表示している。ここでは日付の列(列名「data」)でソートを行っており、もともと降順でソートされていたレコードが昇順でソートされたのが分かる。
なお、本稿はあくまでデータテーブル内のレコードのソート方法について述べたものであり、ソートされたレコードをDataGridコントロールなどに表示したいだけであれば、ソートされたデータビューをコントロールに連結するだけでよい(参考「.NET TIPS:DataGridコントロールで並び替え順やフィルタを指定するには?」)。![]()
| カテゴリ:データベース 処理対象:データテーブル 使用ライブラリ:DataTableクラス(System.Data名前空間) 使用ライブラリ:DataViewクラス(System.Data名前空間) 使用ライブラリ:DataRowViewクラス(System.Data名前空間) 関連TIPS:[ASP.NET]DataGridコントロールでデータセットを表示するには? 関連TIPS:DataGridコントロールで並び替え順やフィルタを指定するには? |
| 「.NET TIPS」 |
TechTargetジャパン
- Kinectが切り開く“夢の近未来” (2012/2/2)
日本を含めた世界中でKinect for Windowsセンサー商用版とSDK正式版がリリース。未来のコンピューティングはどう変化するのか? - 3つの視点でネイティブと.NETの適材適所を考察 (2012/1/31)
アプリ開発は「ネイティブ」と「.NET」、どちらが最良? その問いには「適材適所」と答えるしかない。では、“適所”は一体どこかを考察する - SQL Azure Data Sync入門 (2012/1/30)
SQL Azure/SQL Serverデータベース間のデータ同期を簡単に実現するサービスとは? その仕組みや使用手順を解説 - Windows Phoneアプリ市場の現状を分析する (2012/1/27)
Windows Phone のアプリ・ストアに日々登録されている多種多様なアプリ。カテゴリ別のアプリ数は? 市場の現状を明らかにする
|
|
キャリアアップ
スポンサーからのお知らせ
- - PR -
イベントカレンダー
- - PR -



