我是lambda表达式的新手。我想拥有所有具有数字6的status_ID的计数。然后我想将其转换为列表。为查询设置值的正确语法是什么?我在SQL中知道它,但在lambda表达式中却不知道。
return ContextHelperSlowly<Moi>.GetCount(false, x => x.Status_ID == 6).ToList();
亲切的问候
更新
public static int GetCount(Func<T, bool> where, params Expression<Func<T, object>>[] navigationProperties)
{
int list;
using (var context = GetContext())
{
IQueryable<T> dbQuery = context.Set<T>();
if (null != navigationProperties)
{
foreach (Expression<Func<T, object>> navigationProperty in navigationProperties)
{
dbQuery = dbQuery.Include(navigationProperty);
}
}
if (null == where)
{
where = arg => true;
}
list = dbQuery
.Where(x => x.Date_Deleted == null && x.End_Validity == null)
.Where(where)
.Count();
}
return list;
}
答案 0 :(得分:0)
我只想将GetCount方法更改为GetList:
public static List<T> GetList(Func<T, bool> where, params Expression<Func<T, object>>[] navigationProperties)
{
using (var context = GetContext())
{
IQueryable<T> dbQuery = context.Set<T>();
if (null != navigationProperties)
{
foreach (Expression<Func<T, object>> navigationProperty in navigationProperties)
{
dbQuery = dbQuery.Include(navigationProperty);
}
}
if (null == where)
{
where = arg => true;
}
return dbQuery
.Where(x => x.Date_Deleted == null
&& x.End_Validity == null
&& where(x))
.ToList();
}
}
并使用:
return ContextHelperSlowly<Moi>.GetList(false, x => x.Status_ID == 6);
将计数作为int:
return ContextHelperSlowly<Moi>.GetList(false, x => x.Status_ID == 6).Count;
答案 1 :(得分:0)
你为什么要自己编写这些功能?
这将为您提供Status_ID = 6的项目数:
amp
这将为您提供Status_ID = 6的所有条目的列表:
yourList.Count(x => x.Status_ID == 6);
并注意代码风格&#34;。你可以随心所欲地做到这一点,但C#标准将是&#34; StatusId&#34;对于一个财产。