Enum Flags的Nhibernate QueryOver

时间:2012-02-21 14:54:40

标签: nhibernate enums queryover enum-flags

我有QueryOver的查询:

public IList<Person> SearchTest(PersonEnumType type)
{
    var q = SessionInstance.QueryOver<Person>();
    q = q.Where(x => (x.PersonEnumType & type) == type);
    return q.List<Person>();
}

PersonEnumType是枚举标记:

[Flags]
public enum PersonEnumType
{
     Employee1 = 1,
     Employee2 = 2,
     Employee3 = 4
}

这会抛出Could not determine member from (Convert(x.PersonEnumType) & Convert(value(NHibernate.Repository.PersonRepositoryNh+<>c__DisplayClass2).type))

当然这适用于Nhibernate.Linq。

为什么呢?

1 个答案:

答案 0 :(得分:1)

如果您已在地图文件中正确映射了您的媒体资源:

<property name="PersonEnumType" type="MyApp.PersonEnumType, MyApp">
    <column name="Person" default="1" />
</property>

您可以使用过滤器实现您正在寻找的东西 我不知道这是否是唯一的解决方案,但在这里:

您可以创建过滤器定义:

<filter-def name="PersonEnumTypeFilter">
    <filter-param name="personType" type="MyApp.PersonEnumType, MyApp"/>
</filter-def>

并在您的类映射中实现它:

<filter name="PersonEnumTypeFilter" condition="(:personType &amp; PersonEnumType) = PersonEnumType"/>

现在您可以打开过滤器了:

public IList<Person> SearchTest(PersonEnumType type)
{
    SessionInstance.EnableFilter("PersonEnumTypeFilter").SetParameter("personType",   type);
    var q = SessionInstance.Query<Person>();
    return q.ToList<Person>();
}

您可以详细了解过滤器here