我使用的是带有MVC的EF 3.5。
我想做一个搜索页,有像日期,整数等标准的一些字段。
在linq to entities中动态过滤结果的方法是什么。
如果有一个参数,我们可以使用.where(a=>a.id==1)
但是有许多可选参数的组合,我如何加载结果,然后传递给模型。
发布于 2010-01-16 15:23:36
EF 3.5?不管怎样..。
您可以在ObjectQuery、ObjectSet或IQueryable上附加搜索条件,并根据哪些搜索条件有用来链接它们。
public SearchMyThings( string a, string b, int c )
{
var mywidgets = ObjectContext.CreateObjectSet<Widget>();
//or the EF 1.0 version CreateSet?
if( !a.IsNullOrEmpty )
mywidgets = mywidgets.Where( w => w.AProperty == a );
if( !b.IsNullOrEmpty )
mywidgets = mywidgets.Where( w => w.BProperty == b );
if( c > 0 )
mywidgets = mywidgets.Where( c => c.CProperty == c );
}
如果你需要一种基于字符串的方法,你总是可以使用ObjectQuery.Where的重载(“esql”)来动态构造一些eql并传递它。
如果您需要对字符串进行更多的控制,并且不怕复杂,那么可以尝试一下Dynamic Linq。
https://stackoverflow.com/questions/2076512
复制相似问题