嗨,我有下面的方法,其中有linq语句。
public prO Getproject(int id)
{
var tt = (from c in db.pdi
where c.id==id
select new prO
{
name = c.p.name,
pr_id = c.p.pr_id,
re = c.p.re
});
return tt;
}上面的方法返回tt的一个值。然而,我总是得到智能错误(局部变量) IQueryable<prO>tt
错误:
cannot implicitly convert system.linq.iqueryable to prO请告诉我如何处理这个错误。谢谢
发布于 2014-03-18 07:48:34
您将在查询中返回一个集合。因为您只想要一个项,所以将查询更改为:
public prO Getproject(int id)
{
var tt = (from c in db.pdi
where c.id==id
select new prO
{
name = c.p.name,
pr_id = c.p.pr_id,
re = c.p.re
//change here
}).FirstOrDefault();
return tt;
}错误告诉您如下:您的方法有一个返回类型的prO,但您的查询不返回此类型。您没有任何定义,您正在非常灵活地返回prO的一项。就编译器而言,可能有1000个具有匹配Id的项。
编辑:根据罗林斯的评论,最好用SingleOrDefault()代替。这两种解决方案本身都是有效的,但区别在于FirstOrDefault返回任意数量的结果,但只接受第一个结果,而Single或SingleOrDefault则让查询本身完全返回单个项。
注意,如果查询返回多个结果,FirstOrDefault将显示第一个结果。SingleOrDefault将抛出一个异常。
发布于 2014-03-18 07:47:43
使用return tt.FirstOrDefault();
https://stackoverflow.com/questions/22473147
复制相似问题