1

我想使用 Example.Create() 仅通过实例的唯一值进行查询。为此,我需要找出映射文件中设置的唯一键属性的值,如下所示:

  <property name="MyColumn">
    <column name="MyColumn" unique-key="MyUniqueKeyGroup"/>
  </property>

为了更好地理解 - 这是代码的重要部分:

criteria.Add(Example.Create(myObject).SetPropertySelector(new MyPropertySelector()));

[...]

public class MyPropertySelector: NHibernate.Criterion.Example.IPropertySelector
{
    #region IPropertySelector Member

    public bool Include(object propertyValue, string propertyName, IType type)
    {
         /*  here is where I want to check if the property belongs 
          *  to the unique-key group 'MyUniqueKeyGroup' and return true if so 
          */
    }

    #endregion
}

我需要做什么才能确定某个属性是否属于唯一键组“MyUniqueKeyGroup”?

4

1 回答 1

0

您需要探测Nhibernate.Cfg.Configuration对象才能得到它。为了创建 ISessionFactory 实例,您将在某处构建它。像这样的东西可能会起作用:

private NHibernate.Cfg.Configuration _configuration;

[...]

var selector = new MyPropertySelector<MyClass>(_configuration, "MyUniqueKeyGroup");
criteria.Add(Example.Create(myObject)
                    .SetPropertySelector(selector));

[...]

public class MyPropertySelector<T>: NHibernate.Criterion.Example.IPropertySelector
{
    private NHibernate.Cfg.Configuration _onfiguration;
    private IEnumerable<NHibernate.Mapping.Column> _keyColumns;

    public MyPropertySelector(NHibernate.Cfg.Configuration cfg, string keyName)
    {
        _configuration = cfg;
        _keyColumns = _configuration.GetClassMapping(typeof(T))
                                .Table
                                .UniqueKeyIterator
                                .First(key => key.Name == keyName)
                                .ColumnIterator);

    }

    public bool Include(object propertyValue, string propertyName, IType type)
    {
         return _configuration.GetClassMapping(typeof(T))
                          .Properties
                          .First(prop => prop.Name == propertyName)
                          .ColumnIterator
                              .Where(col => !col.IsFormula)
                              .Cast<NHibernate.Mapping.Column>()
                              .Any(col => _keyColumns.Contains(col)))
    }
}

我实际上并没有编译它来检查它是否有效,所以 YMMV。它当然可以变得更有效率!它也不做任何错误条件的捕获(例如,如果你给它一个不正确的键名,或者一个未映射的类类型,那么它会崩溃)。

干杯,约翰

于 2009-09-14T20:52:12.973 回答