需要解决 C# 错误u003Ef__AnonymousType0



我有一个 c# 代码如下,它在 IEnumerable<u003Cu003Ef__AnonymousType0 处显示错误 有人可以告诉我如何解决它。

dataSet = this.GetData.getInfo("SELECT b.nBatchID, td.F_Name &' '& td.M_Name &' '& td.L_Name AS StaffName, b.BatchName FROM (Batch AS b LEFT JOIN BatchTrainer AS bt ON b.nBatchID = bt.nBatchId) LEFT JOIN TrainerDetails AS td ON bt.TrainerId = td.TrainerID", "Batch");
            IEnumerable<u003Cu003Ef__AnonymousType0<object, string, string>> datas = dataSet.Tables[0].Copy().AsEnumerable().GroupBy<DataRow, object>((Func<DataRow, object>) (row => row["nBatchId"])).Select(g =>
            {
              var data = new{ id = g.Key, text = string.Join(",", g.Select<DataRow, string>((Func<DataRow, string>) (r => r["StaffName"].ToString())).ToArray<string>()), Batch = g.Select<DataRow, string>((Func<DataRow, string>) (r => r["BatchName"].ToString())).FirstOrDefault<string>() };
              return data;
            });
            table.Columns.Add("nBatchId", typeof (int));
            table.Columns.Add("StaffName", typeof (string));
            table.Columns.Add("BatchName", typeof (string));
            foreach (var data in datas)
              table.Rows.Add(data.id, (object) data.text, (object) data.Batch);
            dataSet.Tables.Clear();
            dataSet.Tables.Add(table);

处理匿名类型时不要指定类型名称。请改用var来为你制作编译器推断类型:

var datas = dataSet.Tables[0].Copy().AsEnumerable()
             .GroupBy(row => row.Field<int>("nBatchId"))
             .Select(g => new { 
                 id = g.Key, 
                 text = string.Join(",", g.Select(r => r.Field<string>("StaffName")),
                 Batch = g.Select(r => r.Field<string>("BatchName")).FirstOrDefault()
             });

其他注意事项:

  • 不要为 LINQ 扩展方法指定泛型参数。编译器将从源序列的类型推断泛型参数
  • 不要为 LINQ 扩展方法指定谓词的类型。同上,编译器将从源序列推断类型
  • 使用Field<T>("columnName")扩展名进行DataRow以获得类型良好的单元格值
  • 不要仅仅为了查询而创建数据表的副本。LINQ 不会修改原始数据表
  • 不要将传递给方法的值放入数组String.Join。存在接受IEnumerable<T>的方法重载

最新更新