2010-03-02 9 views
14

El código falla en AssertionFailure: "identificador nulo" - FluentNH + SQLServerCE

session.Save(employee);
con AssertionFailure "identificador nulo". ¿Qué estoy haciendo mal?

using FluentNHibernate.Cfg; 
using FluentNHibernate.Cfg.Db; 
using FluentNHibernate.Mapping; 
using NHibernate; 
using NHibernate.Cfg; 
using NHibernate.Tool.hbm2ddl; 

namespace FNHTest 
{ 
    public class Employee 
    { 
     public virtual int Id 
     { 
      get; 
      private set; 
     } 

     public virtual string Name 
     { 
      get; 
      set; 
     } 

     public virtual string Surname 
     { 
      get; 
      set; 
     } 
    } 

    public class EmployeeMap : ClassMap 
    { 
     public EmployeeMap() 
     { 
      Id(e => e.Id); 
      Map(e => e.Name); 
      Map(e => e.Surname); 
     } 
    } 

    public class DB 
    { 
     private static ISessionFactory mySessionFactory = null; 

     private static ISessionFactory SessionFactory 
     { 
      get 
      { 
       if (mySessionFactory == null) 
       { 
        mySessionFactory = Fluently.Configure() 
         .Database(MsSqlCeConfiguration.Standard 
            .ConnectionString("Data Source=MyDB.sdf")) 
         .Mappings(m => m.FluentMappings.AddFromAssemblyOf()) 
         .ExposeConfiguration(BuildSchema) 
         .BuildSessionFactory(); 
       } 
       return mySessionFactory; 
      } 
     } 

     private static void BuildSchema(Configuration configuration) 
     { 
      SchemaExport schemaExport = new SchemaExport(configuration); 
      schemaExport.Execute(false, true, false); 
     } 

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

    public class Program 
    { 
     public static void Main(string[] args) 
     { 
      var employee = new Employee 
      { 
       Name = "John", 
       Surname = "Smith" 
      }; 

      using (ISession session = DB.OpenSession()) 
      { 
       session.Save(employee); 
      } 
     } 
    } 
}
+0

usté por interés - ¿Cuál fue la solución, opción 1 o 2 (u otra)? :-) –

Respuesta

28

Hay un "error" cuando se utiliza NHibernate con las columnas de identidad SQL CE. Hay dos soluciones, que yo sepa:

1 - Establecer la propiedad connection.release_mode-on_close de configuración:

mySessionFactory = Fluently.Configure() 
    .Database(MsSqlCeConfiguration.Standard 
    .ConnectionString("Data Source=MyDB.sdf")) 
    .Mappings(m => m.FluentMappings.AddFromAssemblyOf()) 
    .ExposeConfiguration(BuildSchema) 
    .ExposeConfiguration(x => x.SetProperty("connection.release_mode", "on_close")) 
    .BuildSessionFactory(); 

2 - realizar inserciones en una transacción:

using (ISession session = DB.OpenSession()) 
    using (ITransaction txn = session.BeginTransaction()) 
    { 
     session.Save(employee); 
     txn.Commit(); 
    } 

realizo la pregunta tiene más de un mes pero espero que esta respuesta todavía te sirva.

+0

Encontré la solución antes. Aún así, ¡gracias por la respuesta! – Stefan

+0

Solo por interés: ¿cuál fue la solución, la opción 1 o 2 (u otra)? :-) –

+0

Usé las transacciones. – Stefan

1

Todavía es el verdadero. Incluso primera llamada para seleccionar @@ IDENTITY devuelve el valor corect, pero segundos devuelve null

utilizo

* connection.driver_class = NHibernate.Driver.SqlServerCeDriver dialecto: NHibernate.Dialect.MsSqlCeDialect *

Después añadiendo propiedad * connection.release_mode: on_close * a mi configuración NHIbernate funciona