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类还有一个类型的属性Site

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

现在我想初始化在第一个代码片段中如何设置所有其他属性的属性SiteDailyEntry

我找不到路?

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 回答