2

在我的应用程序中,每次查询之前我都想做以下事情

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 似乎是同样的问题,但没有解决方案......

4

1 回答 1

1

我相信,你已经试图找到答案,你已经搜索了很多。而你没有找到它的原因,是因为你正在尝试做一些非常不寻常的事情。

( Session ISession)抽象是有目的的,它带来了很多优势。如果我们不喜欢从 Session 中获利,我们可以使用StatelessSession的方式,但我们大多需要 Session 的概念。

事实上,我看到的真正问题隐藏在标签“WPF”中。您正在尝试将 NHibernate 与 一起使用WPF,并且 Session 似乎运行了很长时间......然后它可以返回过时的数据......

解决方案应该是正确的 WPF/NHibernate 会话生命周期设置,可能对您来说最好的来源是:

使用 NHibernate 构建桌面待办事项应用程序

于 2013-09-25T02:36:21.510 回答