我正在构建一个页面,将LINQ查询结果显示为表格。
我收到错误
无法将lambda表达式转换为'string'类型,因为它不是委托类型
在代码
的行this.articles = from art in this.articles
where art.category_id == this.categoryId
select art;
如何修改下面的代码?
namespace WebApplication3 {
public partial class _Default : System.Web.UI.Page {
private IQueryable articles;
protected void Page_Load(object sender, EventArgs e) {
this.SetupArticleQuery();
this.UpdateFilter();
}
private void SetupArticleQuery() {
this.articles = from a in KB.Articles
join t in KB.Teams on a.primary_team_id equals t.id
join cat in KB.Categories on a.category_id equals cat.id
join scat in KB.SubCategories on a.subcategory_id equals scat.id
join top in KB.Topics on a.topic_id equals top.id
select new {
a.id,
a.title,
a.view_count,
a.created_at,
a.created_by,
a.primary_team_id,
primary_team_name = t.name,
category_id = cat.id,
category_name = cat.name,
subcategory_id = scat.id,
subcategory_name = scat.name,
topic_id = top.id,
topic_name = top.name
};
}
private void UpdateFilter() {
if (this.categoryId > 0) {
this.articles = from art in this.articles
where art.category_id == this.categoryId
select art;
}
}
}
答案 0 :(得分:28)
我必须添加以下内容才能让此错误消失。
using System.Data;
using System.Data.Entity;
答案 1 :(得分:13)
答案 2 :(得分:5)
此查询:
this.articles = from a in KB.Articles
join t in KB.Teams on a.primary_team_id equals t.id
join cat in KB.Categories on a.category_id equals cat.id
join scat in KB.SubCategories on a.subcategory_id equals scat.id
join top in KB.Topics on a.topic_id equals top.id
select new {
a.id,
a.title,
a.view_count,
a.created_at,
a.created_by,
a.primary_team_id,
primary_team_name = t.name,
category_id = cat.id,
category_name = cat.name,
subcategory_id = scat.id,
subcategory_name = scat.name,
topic_id = top.id,
topic_name = top.name
};
不会像这样工作,因为它返回一个匿名类型。因此,您必须将其键入为var
,这对于类级别成员无效;你只能将var用于局部变量。
您需要做的是创建一个实际的类来保存您的投影,并具有以下内容:
...
join top in KB.Topics on a.topic_id equals top.id
select new LocalDTO()
{
id = a.id,
...
};
从那里你可以得到:
private void UpdateFilter()
{
if (this.categoryId > 0)
this.articles = this.articles.Where(a => art.category_id);
}
当然,this.articles将声明为IQueryable<LocalDTO>
。
答案 3 :(得分:1)
如果是匿名类型的问题,你可以这样做吗?
private void UpdateFilter() {
if (this.categoryId > 0) {
this.articles = this.articles.Where(a => a.category_id == this.categoryId).AsQueryable();
}
}
这可能是基础的,因为基础的lambda是相同的。