C# LINQ サンプル
概要
compile and run. |
後輩と久しぶりにお話したら、C# で SQL の話題が出たので、C# で SQL を叩くのを作ろうと思ったけれど、LINQ という機能が C# ver 3 から追加されたそうなので、その新機能の動作確認サンプルを作ってみた。
ソースコード
/* * 後輩と話していたら、C# で SQL の話題が出たので、 * C# で SQL を叩くのを作ろうと思ったけれど、LINQ という機能が C# ver 3 から追加されたそうなので、 * その新機能の動作確認サンプルを作ります。 * 2014 / 12 / 04 * jskny / risdy.net */ using System; using System.Linq; class Test { public static int Main() { // 売上データベース // id, name, お気に入り登録数, 買われた数 var Database = new[] { new { id = 1, name = "つけ麺", fav = 1, bought = 53 }, new { id = 2, name = "タンメン", fav = 10, bought = 641 }, new { id = 3, name = "イケメン", fav = 30, bought = 42 }, new { id = 4, name = "ラーメン", fav = 400, bought = 42 }, new { id = 5, name = "ぽよ麺", fav = 400, bought = 869 }, new { id = 6, name = "ぽぽぽ~ん", fav = 20, bought = 1630 }, new { id = 7, name = "塩ラーメン", fav = 8, bought = 352 }, new { id = 8, name = "味噌ラーメン", fav = 90, bought = 6885 }, new { id = 9, name = "お寿司", fav = 3, bought = 35 } }; // 全要素出力 System.Console.WriteLine("VIEW ALL DB."); foreach (object t in Database) { System.Console.WriteLine(t); } // 500回以上買われた商品名のみ出力 System.Console.WriteLine("VIEW OVER 500 BOUGHT."); var boughtUp500 = from t in Database where t.bought >= 500 orderby t.id select t.name; foreach (var t in boughtUp500) { System.Console.WriteLine(t); } // お気に入り登録数が100より多いものを取り出す。 System.Console.WriteLine("VIEW FAV 100 BOUGHT."); var favUp100 = from t in Database where t.fav >= 100 orderby t.id select t.name; foreach (var t in favUp100) { System.Console.WriteLine(t); } return (0); } }
コンソール
VIEW ALL DB. { id = 1, name = つけ麺, fav = 1, bought = 53 } { id = 2, name = タンメン, fav = 10, bought = 641 } { id = 3, name = イケメン, fav = 30, bought = 42 } { id = 4, name = ラーメン, fav = 400, bought = 42 } { id = 5, name = ぽよ麺, fav = 400, bought = 869 } { id = 6, name = ぽぽぽ~ん, fav = 20, bought = 1630 } { id = 7, name = 塩ラーメン, fav = 8, bought = 352 } { id = 8, name = 味噌ラーメン, fav = 90, bought = 6885 } { id = 9, name = お寿司, fav = 3, bought = 35 } VIEW OVER 500 BOUGHT. タンメン ぽよ麺 ぽぽぽ~ん 味噌ラーメン VIEW FAV 100 BOUGHT. ラーメン ぽよ麺