派对可以有一个或多个联系人对象。
我想选择所有街道名称包含特定关键字的派对 如果我只想在 Party 中搜索,我可以使用下面的代码。但是如何将其扩展为也在联系人中搜索?
public IQueryable<Party> SearchParties(List<string> keywords)
{
var predicate = PredicateBuilder.False<Party>();
foreach (string word in keywords)
{
var keyword = word;
predicate = predicate.Or(p => p.surname.Contains(keyword));
predicate = predicate.Or(p => p.lastname.Contains(keyword));
predicate = predicate.Or(p => p.number.Contains(keyword));
}
return db.Parties.Where(predicate);
}
还有什么需要知道的吗?
修改
我想我可以创建另一个谓词然后加入它们。类似的东西:
var predicate2 = PredicateBuilder.False<Contact>();
......并且在foreach中:
predicate2 = predicate2.Or(p => p.streetname.Contains(keyword));
但是如何在返回之前加入谓词和谓词2?
EDIT2
或者,在执行谓词生成器之前加入 Party 和联系?
EDIT3
以下是生成的类的一部分:
[global::System.Data.Linq.Mapping.TableAttribute(Name="dbo.Contact")]
public partial class Contact : INotifyPropertyChanging, INotifyPropertyChanged
{
private static PropertyChangingEventArgs emptyChangingEventArgs = new PropertyChangingEventArgs(String.Empty);
private int _id;
// ...more properties
private EntityRef<Party> _Party;
public Contact()
{
this._Party = default(EntityRef<Party>);
OnCreated();
}
}
答案 0 :(得分:5)
关键是你有一个Party有多个联系人,因此如果“任何联系人与街道名称匹配”或“所有联系人都与街道名称匹配”,您应该决定是否要参加一个Party。
对于第一种情况,它将是:
predicate = predicate.Or(p => p.Contacts.Any(c => c.streetname.Contains(keyword))));
答案 1 :(得分:1)
如果您的模型将联系人作为聚会对象上的关联对象(并且如果它没有一对多关系),这将起作用
predicate = predicate.Or(p => p.Contact.streetname.Contains(keyword));