0

我在使用 Fluent nHibernate 时遇到了一些问题。我在表中添加了一列,我认为我已经正确地更改了映射和连接的数据对象以正确反映这一点。但是,当我再次尝试运行我的应用程序时,我不断收到此错误:

System.Data.SqlClient.SqlException: Invalid column name 'Workflow_id'.

我真的看不出我所做的更改有什么问题,所以我从源代码控制恢复到映射和数据对象文件的原始版本,并从数据库中删除了有问题的列。但我仍然遇到同样的错误。

我想要一些关于如何调试的建议。报告错误的 SQL 是半无意义的:

SELECT regions0_.Page_id as Page5_1_, regions0_.Id as Id1_, regions0_.Id as Id27_0_, regions0_.RegionId as RegionId27_0_, regions0_.RegionTemplate_id as RegionTe3_27_0_, regions0_.Workflow_id as Workflow4_27_0_ FROM [Region] regions0_ WHERE regions0_.Page_id=?

而且它无论如何都不会作为有效的 SQL 执行。

关于从这里去哪里的任何想法?

4

1 回答 1

1

我认为您不需要调试 FluentNhibernate。问题可能出在您的约定中。

据我了解,您有一个对象区域,它被引用到其他对象工作流。因此,为所有参考链接 eq 设置一个约定:

        private  Action<IConventionFinder> GetConventions() 
        {
            return c =>
                { 
                    c.Add<PrimaryKeyConvention>();
                    c.Add<ReferenceConvention>();
                    c.Add<HasManyConvention>();
                    c.Add<TableNameConvention>();
                    c.Add<PropertyNameConvention>();
                };
        }

在你的实现中使用这个私有方法

 public AutoPersistenceModel Generate()

参考约定应该是这样的:

using FluentNHibernate.Conventions;
using FluentNHibernate.Conventions.Instances;

public class ReferenceConvention : IReferenceConvention
{
    public void Apply(IManyToOneInstance instance)
    {
        instance.Column(Inflector.Net.Inflector.Camelize(instance.Property.Name) + "Id");
    }
}

如果是这种情况,还要检查您是否覆盖了映射。

我有一个 unittest 女巫导出映射。不幸的是,下面是旧版本:

[Test, Ignore("Run this test only if you want to see mappings")]
    public void ShouldExportMappings()
    {
        const string mappingPath = @"mappings";

        if (!Directory.Exists(mappingPath))
            Directory.CreateDirectory(mappingPath);

        var sessionFactory = Fluently.Configure()
            .Database(SQLiteConfiguration.Standard.InMemory)
            .Mappings(m =>
                          {
                              m.FluentMappings
                                  .AddFromAssemblyOf<User>()
                                  .ExportTo(mappingPath);

                              m.AutoMappings
                                  .Add(new AutoPersistenceModelGenerator().Generate())
                                  .ExportTo(mappingPath);
                          }).BuildSessionFactory();
    } 

最后,如果您真的想调试,请从存储中复制 FluentNHibernate 源并将其包含到您的 sln 中。但这不是一个好主意,因为问题出在您的代码而不是他们的代码中。这无济于事,您只会浪费时间。

于 2010-06-08T11:43:08.913 回答