3

ASP.NETMVC4アプリケーションでコードファーストエンティティとマッピングを使用してPostgreSQLとFluentNHibernateを使用しています。

アプリケーションを実行すると、データベースからすべてのレコードが自動的に削除されます。

これは私のNHibernateHelperクラスです

public class NHibernateHelper
{
    private static ISessionFactory _sessionFactory;

    private static ISessionFactory SessionFactory 
    {
        get 
        {
            if (_sessionFactory == null)
                InitializeSessionFactory();
            return _sessionFactory;
        }
    }

    private static void InitializeSessionFactory()
    {
        _sessionFactory = Fluently.Configure()
            .Database(PostgreSQLConfiguration.Standard
                        .ConnectionString(
                            @"Server=localhost;Port=5432;Database=TestDB;User=postgres;Password=postgre;")
                        .ShowSql()
            )
            .Mappings(m => m.FluentMappings.AddFromAssemblyOf<ProductCategory>())
            .ExposeConfiguration(cfg => new SchemaExport(cfg)
                            .Create(true, true))
            .BuildSessionFactory();
    }

    public static ISession OpenSession() 
    {
        return SessionFactory.OpenSession();
    }

間違った構成はありますか?

4

1 に答える 1

8

問題はここにあると思います:

.ExposeConfiguration(cfg => new SchemaExport(cfg).Create(true,true))

セッションファクトリを構築するたびにスキーマをエクスポートしているようです。今は100%確信が持てません(コードファーストを使用してテーブルを生成したことはなく、事前に作成した既存のデータベースにマップしただけです)、エクスポートによって既存のものが上書きされるに違いありません(ドロップ&再作成など) .

ここで誰かが、Fluent NHibernate でスキーマをエクスポートするときに SQLite ファイルが上書きされるという同様の問題を抱えていたので、いつ、どのようにデータベースを (再) 作成するかに注意する必要があると思います :)

于 2013-03-02T21:30:21.277 に答える