English 中文(简体)
Fluent nHibernate keeps recreating my database, why?
原标题:

I m trying to convert my data layer from Linq2Sql to nHibernate. I think Xml the configuration in nHibernate is pretty backwards so I m using Fluent.

I ve managed to get fluent, add in a repository pattern and unit of work pattern, and my unit tests are looking good.

However now as I m plugging it into my services layer I m noticing that each time I run my app the database gets recreated.

I am guessing this is down to my SessionProvider code, I m not sure of all the extensions I m using. Can someone shed some light on how to stop this from happening?

public sealed class SessionProvider
{
    private static ISessionFactory _sessionFactory;

    private static ISessionFactory CreateSessionFactory()
    {
        try
        {
            return Fluently.Configure()
                .Database(MsSqlConfiguration.MsSql2005
                              .ConnectionString(Properties.Settings.Default.DBConnection)
                              .Cache(c => c
                                              .UseQueryCache()
                                              .ProviderClass<HashtableCacheProvider>())
                              //.ProxyFactoryFactory("NHibernate.ByteCode.Castle.ProxyFactoryFactory,NHiber nate.ByteCode.Castle")
                              .ShowSql())
                              .Mappings(m=>m.FluentMappings.AddFromAssembly(Assembly.GetExecutingAssembly()))
                .ExposeConfiguration(BuildSchema)
                .BuildSessionFactory();
        }
        catch (Exception ex)
        {
            System.Diagnostics.Debug.WriteLine(ex.Message);
            return null;
        }


    }

    public static ISessionFactory SessionFactory
    {
        get
        {
            if (_sessionFactory == null)
            {
                _sessionFactory = CreateSessionFactory();
            }
            return _sessionFactory;
        }
    }

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

    private static void BuildSchema(Configuration config)
    {
        // this NHibernate tool takes a configuration (with mapping info in)
        // and exports a database schema from it
        new SchemaExport(config).Create(false, true);
    }
}
最佳回答

Remove this line

.ExposeConfiguration(BuildSchema)

Read more about new SchemaExport(config).Create(false, true); here

Actually last argument is all about to create database.

问题回答

暂无回答




相关问题
Anyone feel like passing it forward?

I m the only developer in my company, and am getting along well as an autodidact, but I know I m missing out on the education one gets from working with and having code reviewed by more senior devs. ...

How to Add script codes before the </body> tag ASP.NET

Heres the problem, In Masterpage, the google analytics code were pasted before the end of body tag. In ASPX page, I need to generate a script (google addItem tracker) using codebehind ClientScript ...

Transaction handling with TransactionScope

I am implementing Transaction using TransactionScope with the help this MSDN article http://msdn.microsoft.com/en-us/library/system.transactions.transactionscope.aspx I just want to confirm that is ...

System.Web.Mvc.Controller Initialize

i have the following base controller... public class BaseController : Controller { protected override void Initialize(System.Web.Routing.RequestContext requestContext) { if (...

Microsoft.Contracts namespace

For what it is necessary Microsoft.Contracts namespace in asp.net? I mean, in what cases I could write using Microsoft.Contracts;?

Separator line in ASP.NET

I d like to add a simple separator line in an aspx web form. Does anyone know how? It sounds easy enough, but still I can t manage to find how to do it.. 10x!

热门标签