[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 2chのread.cgiへ]
Update time : 03/05 11:29 / Filesize : 198 KB / Number-of Response : 698
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

【VB.NET】LINQ友の会【C#, C♯, C#】



53 名前:デフォルトの名無しさん mailto:sage [2008/02/16(土) 17:54:00 ]
Q.表を結合したい3(非等価結合、やや使う違いない)
 let を使って、選択した行を保持する事により実現できます。
 class 得点表 { public string 氏名 { set; get; } public int 得点 { set; get; } }
 class 評価表 { public int 以上 { set; get; } public int 未満 { set; get; } public string 評価 { set; get; } }
 class 氏名と評価 { public string 氏名 { set; get; } public string 評価 { set; get; } }
 
var tableOrg1 = new 得点表[] {
 new 得点表() { 氏名="Aさん" , 得点=10 },
 new 得点表() { 氏名="Bさん" , 得点=100 },
 new 得点表() { 氏名="Cさん" , 得点=60 },
};
var tableOrg2 = new 評価表[] {
 new 評価表() { 以上=0 , 未満=20, 評価="丙" },
 new 評価表() { 以上=20 , 未満=70, 評価="乙" },
 new 評価表() { 以上=70 , 未満=101, 評価="甲" },
};
var table1 = from row1 in tableOrg1
  let selectLines = from row2 in tableOrg2 where (row2.以上 <= row1.得点 && row1.得点 < row2.未満) select row2
  select new 氏名と評価() { 氏名 = row1.氏名, 評価 = selectLines.First().評価 };
table1 の結果
 Aさん 丙
 Bさん 甲
 Cさん 乙
あんま綺麗じゃない……equalsに対してLINQの拡張求む > Microsoft






[ 続きを読む ] / [ 携帯版 ]

全部読む 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<198KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef