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 :

JBoss, Hibernate et ConstraintViolationException


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    117
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 117
    Par défaut JBoss, Hibernate et ConstraintViolationException
    Bonjour,

    Je travaille sur un projet avec une couche services JBoss EJB3 et hibernate pour la persistence. C'est JBoss qui gère mes transactions Hibernate.

    J'ai du mal à comprendre un phénomène qui se produit sur la suppression d'un objet dont dépendent plusieurs objets par foreign key :

    1/ Si je supprime avec Hibernate comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    HibernateUtils.getCurrentSession().delete(entity);
    Je récupère une org.hibernate.exception.ConstraintViolationException qu'une fois sorti de mon service (dans le front).

    2/ Si je fais ma suppression en HQL, l'exception est jetée juste après le executeUpdate() (je peux donc la catcher dans mon service) et la transaction rollback bien.

    J'essaie de comprendre pourquoi je n'ai pas le même comportement dans les 2 cas. Pour moi l'explication est qu'Hibernate fait un flush de la session juste après un executeUpdate(), mais seulement à la fin du service sur un delete hibernate.

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2009
    Messages : 92
    Par défaut
    Effectivement, suite à une requête HQL, Hibernate génère tout de suite la requête SQL correspondante, et donc un flush() est effectué (pour assurer la synchronisation entre la bdd et les objets persistants Java), alors que session.delete() est mis en attente et la requête SQL correspondante est exécutée au plus tard juste avant la fin de la transaction.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    117
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 117
    Par défaut
    Bon ben finalement je catch mes SQLException dans mon business delegate et je m'en sors avec les errorCode. Un peu crado mais je vois pas comment faire autrement pour l'instant...

    Sinon en lisant la doc Hibernate :

    If you work in a CMT environment, you might also want to use the same entity manager in different parts of your code. Typically, in a non-managed environment you would use a ThreadLocal variable to hold the entity manager, but a single EJB request might execute in different threads (e.g. session bean calling another session bean). The EJB3 container takes care of the persistence context propagation for you. Either using injection or lookup, the EJB3 container will return an entity manager with the same persistence context bound to the JTA context if any, or create a new one and bind it (see Section 1.2.4, “Persistence context propagation” .)

    Our entity manager/transaction management idiom for CMT and EJB3 container-use is reduced to this:

    //CMT idiom through injection
    @PersistenceContext(name="sample") EntityManager em;

    In other words, all you have to do in a managed environment is to inject the EntityManager, do your data access work, and leave the rest to the container. Transaction boundaries are set declaratively in the annotations or deployment descriptors of your session beans. The lifecycle of the entity manager and persistence context is completely managed by the container.
    Je ne comprends pas trop le sens, car pour mes opérations de persistence côté back je passe par la session hibernate obtenue comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    new AnnotationConfiguration().configure().buildSessionFactory().getCurrentSession();

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2009
    Messages : 92
    Par défaut
    tu peux aussi ajouter une lecture de vérification dans ta règle métier avant de demander le delete et renvoyer alors une exception applicative appropriée

Discussions similaires

  1. Réponses: 6
    Dernier message: 24/09/2011, 13h03
  2. Transaction JBoss / Hibernate
    Par Nertios dans le forum Wildfly/JBoss
    Réponses: 2
    Dernier message: 25/03/2010, 16h31
  3. Réponses: 2
    Dernier message: 25/08/2009, 16h30
  4. jboss / hibernate : no suitable driver
    Par mouaa dans le forum Wildfly/JBoss
    Réponses: 1
    Dernier message: 10/11/2008, 12h29
  5. [JBoss + hibernate] erreur autocommit
    Par pmartin8 dans le forum Hibernate
    Réponses: 5
    Dernier message: 02/05/2007, 15h01

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