我第一次使用NHibernate,但希望能够通过NHibernate Fluent尽可能避免使用配置文件。我有一个项目设置,我正在尝试使用以下
查询地址对象[TestMethod]
public void TestMethod1()
{
var cfg = Fluently.Configure()
.Database(MsSqlConfiguration.MsSql2008.ConnectionString(c => c.Is("[ConnectionStringHere")))
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<RedSand.Models.Data.Mapping.AddressMapping>());
var sessionFactory = cfg.BuildSessionFactory();
var session = sessionFactory.OpenSession();
session.Get<Address>(new Guid("A8B9BA39-425D-4AE6-A72E-00216ABC87C4"));
}
然而,它在Get<T>()
方法上爆炸,并且抱怨没有持久性的错误。我的地址类如下。
public class Address
{
public Guid AddressId { get; set; }
public string AddressType { get; set; }
public string StreetAddress { get; set; }
public Guid CityId { get; set; }
public string PostalCode { get; set; }
public bool DefaultAddress { get; set; }
public bool TermAddress { get; set; }
public string SuiteNumber { get; set; }
public float Latitude { get; set; }
public float Longitude { get; set; }
public int Accuracy { get; set; }
}
public class AddressMapping : ClassMap<Address>
{
public AddressMapping()
{
Table("tblAddress");
Not.LazyLoad();
Id(a => a.AddressId).Column("AddressID").GeneratedBy.Guid();
Map(a => a.StreetAddress).Column("Address").Length(100);
Map(a => a.CityId).Column("CityID");
Map(a => a.PostalCode).Length(50);
Map(a => a.DefaultAddress);
Map(a => a.TermAddress).Default("0");
Map(a => a.SuiteNumber).Column("SuiteNo").Length(50);
Map(a => a.Latitude);
Map(a => a.Longitude);
Map(a => a.Accuracy);
}
}
我正在使用现有数据库,因此请尝试忽略时髦的表结构/命名。
我在这里遗漏了什么吗?你们中的任何人都可以看到一些可以解释为什么它会抱怨No persister吗?
答案 0 :(得分:3)
AddFromAssemblyOf
中的程序集应该是映射类,而不是映射文件。地址是否与AddressMapping不同的程序集?尝试将其更改为AddFromAssemblyOf<YourNamespace.Address>
。