3

我在我的实体中使用了lazyload 属性。它工作正常,但是当通过方法更改此类中的任何属性时,NHibernate 不会进行更新。如果直接更改属性,则一切正常。

我想如果返回惰性属性代理对象并且该代理不处理内部更改,则存在该问题。

我在下面添加了测试代码。它在 NHibernate 3.1 中运行良好,但在 NHibernate 3.2 和 3.3 中不调用更新

也许有人知道如何解决这个问题?

谢谢。

实体:

/// <summary>
/// Class for testing lazy properties.
/// </summary>
public class TestClass
{
    public virtual int Id { get; set; }
    public virtual string LazyData { get; set; }
    public virtual string TestData { get; set; }

    public virtual void ChangeTestData(string data)
    {
        TestData = data;
    }
}

映射:

public class TestClassMap : ClassMap<TestClass>
{
    public TestClassMap()
    {
        Id(m => m.Id);
        Map(m => m.LazyData).LazyLoad();
        Map(m => m.TestData);
    }
}

测试代码:

[Test]
public void LazyProperityTest1()
{
    var testObj = new TestClass();
    Session.Save(testObj);
    Session.Flush();
    Session.Clear();

    // Change property and flush session.
    var persistedObj = Session.CreateCriteria<TestClass>().List<TestClass>().First();
    persistedObj.ChangeTestData("test");

    Session.Flush();
    Session.Clear();
}

设置 LazyLoad 时生成的 sql 请求:

NHibernate: INSERT INTO "TestClass" (LazyData, TestData) VALUES (@p0, @p1); select last_insert_rowid();@p0 = NULL [Type: String (0)], @p1 = NULL [Type: String (0)]
NHibernate: SELECT this_.Id as Id0_0_, this_.TestData as TestData0_0_ FROM "TestClass" this_

未设置 LazyLoad 时生成的 sql 请求:

NHibernate: INSERT INTO "TestClass" (LazyData, TestData) VALUES (@p0, @p1); select last_insert_rowid();@p0 = NULL [Type: String (0)], @p1 = NULL [Type: String (0)]
NHibernate: SELECT this_.Id as Id0_0_, this_.LazyData as LazyData0_0_, this_.TestData as TestData0_0_ FROM "TestClass" this_
NHibernate: UPDATE "TestClass" SET LazyData = @p0, TestData = @p1 WHERE Id = @p2;@p0 = NULL [Type: String (0)], @p1 = 'test' [Type: String (0)], @p2 = 1 [Type: Int32 (0)]
4

1 回答 1

1

这对我来说绝对是一个错误,你有一个很好的测试用例来证明它。

请在https://nhibernate.jira.com/输入问题

于 2013-03-14T12:41:30.420 回答