0
.
.
List<DailyEntry> entries = null;
using (SqlCeDataReader rdr = cmd.ExecuteReader())
{
    entries = rdr.Select(r => new DailyEntry
    {
        ID = int.Parse(r["Col_ID"].ToString()),
        Amount = decimal.Parse(r["Col_Amount"].ToString()),
        Date = DateTime.Parse(r["Col_Date"].ToString()),
        Remarks = r["Col_Remarks"].ToString()
    }).ToList();
}
.
.

伸展法select

 public static IEnumerable<T> Select<T>(this SqlCeDataReader reader,
                                        Func<SqlCeDataReader, T> projection)
 {
     while (reader.Read())
     {
         yield return projection(reader);
     }
 }

DailyEntryクラスはどこにありますか

class DailyEntry
{
    public int ID { get; set; }
    public DateTime Date { get;set; }
    public Site Site { get; set; }
    public decimal Amount { get; set; }
    public string Remarks { get; set; }
}

DailyEntryクラスにはもう1つのタイプのプロパティがありますSite

class Site
{
    public int SiteID { get; set; }
    public string SiteName { get; set; }
}

次に、最初のコードスニペットで他のすべてのプロパティがどのように設定されているかというSiteプロパティを初期化します。DailyEntry

私は道を見つけていませんか?

4

3 に答える 3

1

なぜ既存の関数を使用しないのですか? このようなもの:

entries = rdr.Select(r => new DailyEntry
    {
        ID = int.Parse(r["Col_ID"].ToString()),
        Amount = decimal.Parse(r["Col_Amount"].ToString()),
        Date = DateTime.Parse(r["Col_Date"].ToString()),
        Remarks = r["Col_Remarks"].ToString(),
        Site = new Site {SideID = r["..."], SiteName = r["..."]}
    }).ToList();
于 2011-11-08T15:56:34.620 に答える
1

DailyEntry新しいインスタンスを作成するのと同じ方法でインラインで作成するだけです。

rdr.Select(r => new DailyEntry
{
    ID = int.Parse(r["Col_ID"].ToString()),
    Amount = decimal.Parse(r["Col_Amount"].ToString()),
    Date = DateTime.Parse(r["Col_Date"].ToString()),
    Remarks = r["Col_Remarks"].ToString(),
    Site = new Site 
           {
               SiteID = int.Parse(r["Site_ID"].ToString()),
               SiteName = r["Site_Name"].ToString()
           }
}
于 2011-11-08T15:56:54.130 に答える
1

私が質問を理解していない場合を除き、答えは次のとおりです。

List<DailyEntry> entries = null;
using (SqlCeDataReader rdr = cmd.ExecuteReader())
{
    entries = rdr.Select(r => new DailyEntry
    {
        ID = int.Parse(r["Col_ID"].ToString()),
        Amount = decimal.Parse(r["Col_Amount"].ToString()),
        Date = DateTime.Parse(r["Col_Date"].ToString()),
        Remarks = r["Col_Remarks"].ToString(),
        Site = new Site 
        {
            SiteID = int.Parse(r["Site_ID"].ToString()),
            SiteName = r["name"].ToString()
        }
    }).ToList();
}
于 2011-11-08T15:57:09.840 に答える