无法隐式转换类型“System.Linq.IQueryable <>来。 一个显式转

2019-11-01 17:09发布

我有以下代码:

private GolfManagementEntities db = new GolfManagementEntities();

    public class ThanhToan
    {
        public ThanhToan()
        { }
        public Double Total { get; set; }
        public DateTime date { get; set; }
    }

    public List<ThanhToan> listInvoice(DateTime tuNgay, DateTime denNgay)
    {

       List<ThanhToan> invoice= from i in db.Invoices 
                                where i.Date >= tuNgay && i.Date <= denNgay 
                                group i by i.Date into In 
                                select new ThanhToan { 
                                    date= Convert.ToDateTime(In.Key) , 
                                    Total = Convert.ToDouble(In.Sum(s => s.ExtendedCost))
                               };

       return invoice;

}

而我得到这个错误:

无法隐式转换类型“System.Linq.IQueryable <>来。 一个显式转换存在(是否缺少强制转换?)

请帮我

Answer 1:

您的查询返回IQueryable<THanhToan>但你试图返回一个List<ThanhToan> 有没有可用的隐式转换(按照错误消息),但你可以使用ToList扩展方法创建一个列表:

public List<ThanhToan> ListInvoices(DateTime tuNgay, DateTime denNgay)
{

    var query = from i in db.Invoices 
                where i.Date >= tuNgay && i.Date <= denNgay
                group i by i.Date into g
                select new ThanhToan {
                    date = Convert.ToDateTime(g.Key), 
                    Total = Convert.ToDouble(g.Sum(s => s.ExtendedCost))
                };
    return query.ToList();
}

(我已经改变了你的方法名遵循.NET命名约定,使更多的意义在返回张发票,而不是它只是条件之一。另外还要注意如何传播查询多行使得它容易阅读。)



文章来源: Cannot implicitly convert type 'System.Linq.IQueryable<>to . An explicit conversion exists (are you missing a cast?)