1

这是(编辑的)域类:

public class Patient : IntegerKeyEntity
{
  ...
  public virtual string LastName
  {
      get
      {
          return Encoding.Unicode.GetString(encryptionService.Decrypt(LastNameEncrypted));
      }
      set
      {
          LastNameEncrypted = encryptionService.Encrypt(value);
      }
  }
  /// <summary>
  /// Contains the encrypted last name. Access via LastName for unencrypted version.
  /// </summary>
  public virtual byte[] LastNameEncrypted { get; set; }
  ...
}

这是 Fluent 映射:

public class PatientMap : ClassMap<Patient>
{
  public PatientMap()
  {
    ...
    Map(x => x.LastNameEncrypted, "LastName")
      .Not.Nullable();
    ...
  }
}

我没有在 Patient 中映射 LastName。该表有一个 LastName 列(一个 varbinary)并且没有 LastNameEncrypted 列。

这是查询:

public virtual IQueryable<TResult> SatisfyingElementsFrom(IQueryable<T> candidates, int start, int limit, string sort, string dir)
{
    if (this.MatchingCriteria != null)
    {
        return candidates.Where(this.MatchingCriteria).OrderBy(sort + " " + dir).Skip(start).Take(limit).ToList().ConvertAll(this.ResultMap).AsQueryable();
    }

    return candidates.ToList().ConvertAll(this.ResultMap).AsQueryable();
} 

返回(在 if 块内)是触发错误的地方。错误显示“无法解析患者的姓氏属性”。

我正在使用 NHibernate (v2.1.2.4000)、Fluent NHibernate (v1.1.0.685) 和 NHibernate.Linq (v1.1.0.1001)。我无法更新这些 DLL。

是因为我没有 Patient.LastName 的映射吗?我没有,也不需要。如果这是问题所在,我如何映射/告诉 Fluent NHibernate 忽略该属性?

PS:我没有使用 AutoMapping,只使用显式映射。它们的加载方式如下。在我的应用程序中,只有 cfg(一个 NHibernate.Cfg.Configuration 对象)和 mappingAssemblies(指向具有映射的一个 DLL)有一个值。

private static ISessionFactory CreateSessionFactoryFor(string[] mappingAssemblies, AutoPersistenceModel autoPersistenceModel, Configuration cfg, IPersistenceConfigurer persistenceConfigurer)
{
    FluentConfiguration fluentConfiguration = Fluently.Configure(cfg);

    if (persistenceConfigurer != null)
    {
        fluentConfiguration.Database(persistenceConfigurer);
    }

    fluentConfiguration.Mappings(m =>
    {
        foreach (var mappingAssembly in mappingAssemblies)
        {
            var assembly = Assembly.LoadFrom(MakeLoadReadyAssemblyName(mappingAssembly));

            m.HbmMappings.AddFromAssembly(assembly);
            m.FluentMappings.AddFromAssembly(assembly).Conventions.AddAssembly(assembly);
        }

        if (autoPersistenceModel != null)
        {
            m.AutoMappings.Add(autoPersistenceModel);
        }

    });

    return fluentConfiguration.BuildSessionFactory();
}
4

1 回答 1

0

执行查询时会发生此错误。查看您的代码,我只看到可能导致问题的一件事 - 即 MatchingCriteria:

return candidates.Where(this.MatchingCriteria)...

this.MatchingCriteria 中存储的是什么类型?

尝试用内联条件替换它:in

..Where(<put_inline_criteria_here>)..
于 2013-01-27T08:40:19.207 回答