我正在尝试使用对 X 个实现包含日期信息的特定接口的实体的析取来添加一定数量的 OR 条件。我的问题是,当生成 SQL 时,我所有的析取条件都指向我的 QueryOver 的根实体。
我创建了一个通用方法来添加我的条件
    public static QueryOver<T,T2> AddChangedCondition<T,T2>(this QueryOver<T,T2> query, DateTime from, DateTime to, Disjunction disjunction) where T2 : IHaveDate
    {
        if(disjunction == null )
            disjunction = new Disjunction();
        disjunction.Add<T2>(k => (k.DeleteDate > from && k.DeleteDate  < to)
                || k.CreatedDate > from
                || k.UpdatedDate > from);
        return query;
    }
我想像这样使用它:
Disjunction disjunction = null;
var query = QueryOver.Of<User>()
    .AddChangedCondition(fromDate,toDate, disjunction)
    .JoinQueryOver<Program>(user => user.Programs)
        .AddChangedCondition(fromDate,toDate, disjunction);
query.Where(disjunction);
由此生成的 Sql 看起来类似于
select ....
from User
where
(
    (
        this_.raderadDatum > @p1 
        and this_.raderadDatum < @p2
    ) 
    or this_.skapadDatum > @p3 
    or this_.uppdateradDatum > @p4
    )
or
    (
        this_.raderadDatum > @p1 
        and this_.raderadDatum < @p2
    ) 
    or this_.skapadDatum > @p3 
    or this_.uppdateradDatum > @p4
    )
我尝试过使用别名的不同解决方案,但没有成功。将不胜感激任何帮助!