IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Hibernate Java Discussion :

[Débutant] erreur : createQuery is not valid without active transaction


Sujet :

Hibernate Java

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 96
    Points : 72
    Points
    72
    Par défaut [Débutant] erreur : createQuery is not valid without active transaction
    Bonjour,

    Je teste hibernate, via eclipse et le plugin hibernate j'ai pu générer mon fichier hibernate.cfg.xml et ma classe java qui correspond à l'unique table de ma base (je fais simple pour commencer).
    Dans le fichier hibernate.cfg.xml j'ai ajouté les lignes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <property name="transaction.factory_class">org.hibernate.transaction.JDBCTransactionFactory</property>
    <property name="current_session_context_class">thread</property>
    <property name="hibernate.show_sql">true</property>
    a la fin de la balise <session-factory> (vu dans un tutoriel)

    Mon problème c'est lorsque je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    listeMachin = sessionFactory.getCurrentSession().createQuery("from machin").list();
    J'ai l'erreur :
    Exception in thread "main" org.hibernate.HibernateException: createQuery is not valid without active transaction
    at org.hibernate.context.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:297)
    at $Proxy0.createQuery(Unknown Source)
    Dans mes recherches celà peut venir de la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <property name="current_session_context_class">thread</property>
    du fichier de conf hibernate pour ceux qui utilise spring ce qui n'est pas mon cas.

    Merci de votre aide.

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    383
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 383
    Points : 468
    Points
    468
    Par défaut
    [QUOTE=david42;3687618]Bonjour,

    Non ça vient plutôt de cette ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <property name="transaction.factory_class">org.hibernate.transaction.JDBCTransactionFactory</property>
    Là tu dis en fait que tu vas gérer toi même les transactions (manuellement).

    Il faut alors écrire du code comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
     
    Session session = null;
    Transaction tx = null;
    try {
      session = sessionFactory.openSession();
      tx = session.beginTransaction();
      tx.setTimeout(5);
      concludeAuction(session);
      tx.commit();
    } catch (RuntimeException ex) {
    try {
      tx.rollback();
    } catch (RuntimeException rbEx) {
      log.error("Couldn’t roll back transaction", rbEx);
    }
    throw ex;
    } finally {
      session.close();
    }
    Sinon, si tu es dans un serveur d'application (avec un transaction manager) tu doit configurer comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <property name="transaction.factory_class">
       org.hibernate.transaction.JTATransactionFactory
    </property>

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 96
    Points : 72
    Points
    72
    Par défaut
    Ok merci.
    C'est donc plus simple finalement de coupler hibernate et spring afin de ne pas avoir à gérer manuellement les transactions.

  4. #4
    Expert éminent
    Avatar de djo.mos
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    4 666
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 666
    Points : 7 679
    Points
    7 679
    Par défaut
    Citation Envoyé par david42 Voir le message
    Ok merci.
    C'est donc plus simple finalement de coupler hibernate et spring afin de ne pas avoir à gérer manuellement les transactions.
    Voilà. C'est l'un des grands avantages de Spring côté ORM : la gestion des transactions, même en dehors d'un conteneur JEE.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 96
    Points : 72
    Points
    72
    Par défaut
    Ok, pas de problème.

    Merci de vos réponses

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 01/08/2011, 14h24
  2. Réponses: 1
    Dernier message: 18/05/2010, 22h14
  3. [A2-VBA][Débutante] Erreur "Argument non valide"
    Par Ericka dans le forum Access
    Réponses: 2
    Dernier message: 08/09/2006, 16h35
  4. Erreur "specified cast is not valid"
    Par [DreaMs] dans le forum Delphi .NET
    Réponses: 1
    Dernier message: 30/01/2006, 21h15
  5. Réponses: 2
    Dernier message: 25/12/2005, 20h03

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo