我有这个QueryOver,我在其中选择日志名称以D或F开头的日志记录(使用通配符)。
conv.InnerTransaction.Session.QueryOver<Log>()
.Where(l => l.DateTime > _datetime)
.And(
l => l.Name.IsLike("D%") || l.Name.IsLike("F%")
)
相反,我希望名称搜索动态使用列表中的值。如何才能做到这一点?
我试过类似的东西:
var query = conv.InnerTransaction.Session.QueryOver<Log>()
.Where(l => l.DateTime > _datetime);
foreach (var name in _names)
{
query = query.And(l => l.Name.IsLike(name));
}
但这会导致列表中的每个名称都有多个 AND 语句,而它只需要是一个 OR。