質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

LINQ

LINQとはLanguage INtegrated Queryの略で、「統合言語クエリ」という意味です。C#やVisual Basicといった言語のコード内に記述することができるクエリです。

Q&A

解決済

1回答

4739閲覧

SQLに対応するLINQの書き方を教えてください。

ohno1011

総合スコア14

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

LINQ

LINQとはLanguage INtegrated Queryの略で、「統合言語クエリ」という意味です。C#やVisual Basicといった言語のコード内に記述することができるクエリです。

0グッド

0クリップ

投稿2019/12/24 01:39

前提・実現したいこと

初めまして。

現在、VB6で作成してあるプログラムをVS2015 C#でリニューアル作成しています。

データを取得して格納してあるmdbからSQL文でデータの抽出をしている処理がありますが、
mdbの使用を廃止しプロジェクト内のDataTableにデータを格納するようにしてあります。

そこで、SQLが使用できなくなるためLINQを使用してDataTableからデータを抽出したいのですが、
実装方法がわからず、ご教示頂きたいと思います。

SELECT MAX(FIELD1),
FIELD2,
FIELD3,
MAX(FIELD4)
FROM MDBNAME
GROUP BY FIELD2, FIELD3, FIELD4
ORDER BY FIELD2, FIELD3

上記のSQLに対応するLINQを[dt]というDataTableに対して行いたいのですが

var query = dt.AsEnumerable()
.GroupBy(x => new {x.FIELD2, x.FIELD3, x.FIELD4})
.Select(x => new {})

Selectに記述する内容がわかりません。

LINQは少しだけ使用したことがありますが集計関数を使用したことはありません。

宜しくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

こんにちは。

動かしてないですが、書いてある通りのクエリだとこれでいいはずです。

csharp

1var query = dt.AsEnumerable() 2 .GroupBy(x => new { x.FIELD2, x.FIELD3, x.FIELD4 }) 3 .Select(x => new { FIELD1 = x.Max(a => a.FIELD1), x.Key.FIELD2, x.Key.FIELD3, FIELD4 = x.Max(a => a.FIELD4) });

GROUP BY で FIELD4 を指定しているのに MAX を通しているのがよく分からないですが、Max を使わなくても同じ結果が得られます。

csharp

1var query = dt.AsEnumerable() 2 .GroupBy(x => new { x.FIELD2, x.FIELD3, x.FIELD4 }) 3 .Select(x => new { FIELD1 = x.Max(a => a.FIELD1), x.Key.FIELD2, x.Key.FIELD3, x.Key.FIELD4 });

投稿2019/12/24 01:54

tamoto

総合スコア4105

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ohno1011

2019/12/24 05:47

回答ありがとうございます。 引き続き質問をさせて頂きたいと思います。 このLINQで取得したデータをDataTableに変換したいのですが、 ``` var query = dt.AsEnumerable() .GroupBy(x => new { x.FIELD2, x.FIELD3, x.FIELD4 }) .Select(x => new { FIELD1 = x.Max(a => a.FIELD1), x.Key.FIELD2, x.Key.FIELD3, TTL = x.Max(a => a.FIELD4) }) .OrderBy(x => x.FIELD2) .ThenBy(x => x.FIELD3) .ToArray(); ``` という処理の後、 ``` DataTable dt2 = new DataTable(); dt2.Columns.add("FIELD1"); dt2.Columns.add("FIELD2"); dt2.Columns.add("FIELD3"); dt2.Columns.add("FIELD4"); foreach(var row in query) { dt2.rows.add(row); } ``` という処理を書きましたが、dt2に1行追加した時点で中身を見てみると 1列目のFIELD1の値が { FIELD1 = ○○, FIELD2 = ××, FIELD3 = △△, FIELD4 = □□ } となり、 2列目~4列目は空白 という結果になってしまいました。 selectの記述方法が良くないのでしょうか? 取得したフィールドをDataTableの各列に渡す方法がわかりましたら、 教えていただけますでしょうか。 宜しくお願い致します。
ohno1011

2019/12/24 06:14

追加の質問について、自己解決しました。 foreach(var row in query) { dt2.rows.add(row.FIELD1, row.FIELD2, row.FIELD3, row.FIELD4 ); } という書き方で希望通りの処理ができました。 tamotoさん、本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問