在我的应用程序中,每次查询之前我都想做以下事情
public List<Supplier> GetAllSuppliers()
{
NHibernateHelper.Session.Clear();
string query = "from Supplier order by FirstName, LastName asc ";
var result = NHibernateHelper.Session.CreateQuery(query).List<Supplier>();
return (List<Supplier>)result ?? new List<Supplier>();
}
以下代码行旨在清除会话,因此当我查询所有供应商时,我希望再次从数据库中获取整个列表,而不是从缓存中获取。因为 NHibernate 会记住该对象或类似的东西,并且不会收到在数据库中所做的更改(我的应用程序在多台计算机上使用,这是我想要获取“实时”数据的主要原因)
NHibernateHelper.Session.Clear();
但是我的 Supplier 对象有一个 Address 对象,该对象正在延迟加载。在我的列表中,我选择了该供应商对象,它显示了它的名称和地址。那就是发生错误的时候:
An unhandled exception of type 'System.Windows.Markup.XamlParseException' occurred in PresentationFramework.dll
Additional information: Initializing[Model.Supplier#1]-Could not initialize proxy - no Session.
如果在注释中设置那行代码它可以工作......但我不希望它使用缓存的行为......
供应商映射
public SupplierMap()
{
Id(x => x.Id);
Map(x => x.Name);
Map(x => x.Btw);
Map(x => x.Email);
Map(x => x.Fax);
Map(x => x.Telephone);
References(x => x.Address).Cascade.All();
HasMany(x => x.Articles);
Table("tbl_suppliers");
}
地址映射
public AddressMap()
{
Id(x => x.Id);
Map(x => x.Street).Length(10000);
Map(x => x.Number).Length(10000);
Map(x => x.Zip).Length(10000);
Map(x => x.City).Length(10000);
Map(x => x.Country).Length(10000);
Table("tbl_addresses");
}
关于这个问题的任何想法?
编辑 我发现以下链接:https://nhibernate.jira.com/browse/NH-2791 似乎是同样的问题,但没有解决方案......