Вот как это можно сделать с помощью API критериев:
[Flags]
enum Bar{
A = 0x01,
B = 0x02,
C = 0x04
}
var criteria = this.Session.CreateCriteria<Foo>()
.Add( BitwiseFlags.IsSet( "Bar", Bar.A | Bar.C ) );
с помощью:
public class BitwiseFlags : LogicalExpression
{
private BitwiseFlags( string propertyName, object value, string op ) :
base( new SimpleExpression( propertyName, value, op ),
Expression.Sql( "?", value, NHibernateUtil.Enum( value.GetType() ) ) )
{
}
protected override string Op
{
get { return "="; }
}
public static BitwiseFlags IsSet(string propertyName, Enum flags)
{
return new BitwiseFlags( propertyName, flags, " & " );
}
}
должен сгенерировать следующий вывод where:
FROM _TABLE
WHERE (this_.Bar & 5 = 5)
, который должен давать вам строки с установленными флагами Bar.A и Bar.C (исключая все остальное). Вы должны быть в состоянии использовать это также с соединением и дизъюнкцией.