0

我有这个QueryOver,我在其中选择日志名称DF开头的日志记录(使用通配符)。

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。

4

1 回答 1

3

你试过Disjunction吗?我曾经有过类似的要求,但我不得不Conjunction改用。Disjunctionor多个条件放在一起。

var disjunction = new Disjunction();
var query = Session.QueryOver<Log>().Where(l => l.DateTime > _datetime);
foreach (var name in _names)
{
    disjunction.Add(Restrictions.On<Log>(log => log.Name).IsLike(name));
}
var queryResult = query.Where(disjunction).List<Log>();
于 2013-04-18T12:03:56.213 回答