2012-05-06 2 views
0

J'ai une application qui utilise Nhibernate. Ceci est ma première application en utilisant ainsi je suis débutant. J'essaie de tester ma première méthode get.La valeur 'hibernate.current_session_context_class' n'est pas valide selon son type de données 'String'

protected void Button1_Click(object sender, EventArgs e) 
{ 
    IList<Person> persons = 
    SessionManager 
     .SessionFactory 
     .GetCurrentSession() 
     .CreateCriteria(typeof(Person)) 
     .List<Person>(); 
} 

est ici le code de la session mgr:

public static partial class SessionManager 
{ 
    private static readonly ISessionFactory _sessionFactory; 

    static SessionManager() 
    { 
    Configuration cfg = new Configuration().Configure(); 
    _sessionFactory = 
     Fluently 
     .Configure(cfg) 
     .Mappings(m => m.FluentMappings.AddFromAssembly(typeof(SessionManager).Assembly)) 
     .BuildSessionFactory(); 
     //CurrentSessionContext.Bind(_sessionFactory.GetCurrentSession()); 
    } 

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

    public static ISessionFactory SessionFactory 
    { 
    get { return _sessionFactory; } 
    } 
} 

Mais chaque fois que j'exécuter l'application et cliquez sur le BTN. il jette une exception à l'exception intérieure msg:

"The 'name' attribute is invalid - The value 'hibernate.current_session_context_class' is invalid according to its datatype 'String' - The Enumeration constraint failed."}

Voici mon hibernate.cfg.xml

<?xml version="1.0" encoding="utf-16"?> 
    <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2"> 
    <session-factory> 
     <property name="hibernate.current_session_context_class">managed</property> 
     <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property> 
     <property name="dialect">NHibernate.Dialect.MsSql2005Dialect</property> 
     <property name="connection.driver_class">NHibernate.Driver.SqlClientDriver</property> 
     <property name="connection.connection_string">Server=localhost\MSSQLSERVERR2;Database=PersonSearch;Trusted_Connection=True</property> 
     <property name="proxyfactory.factory_class">NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle</property> 
     <property name="cache.use_minimal_puts">false</property> 
     <property name="use_outer_join">false</property> 
    </session-factory> 
    </hibernate-configuration> 

Au départ, je ne l'ai pas mis

<property name="hibernate.current_session_context_class">managed</property> 

mais il me donne une erreur :

No CurrentSessionContext configured (set the property current_session_context_class)!

Répondre

0

Si dans une toile l'application, procédez comme suit:

<property name="current_session_context_class">managed_web</property> 

Si dans une application Winform, procédez comme suit:

<property name="current_session_context_class">thread_static</property> 
Questions connexes