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 :

Gestion Contrainte d'unicité


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Par défaut Gestion Contrainte d'unicité
    Bonjour,

    Voila je débute avec Hibernate et j'avais une petite question.
    Dans ma table j'ai une contrainte d'unicité sur un champ "nom" et dans ma classe qui fait le mapping, j'ai également déclaré cette unicité. Jusque là tout va bien (enfin je crois)

    Je voulais savoir comment était gérer cette contrainte, est ce que Hibernate le gère tout seule et dans ce cas il faut juste récupérer l'exception renvoyée ou bien bien faut il faire d'abord un "select" afin de vérifier que le nom n'existe pas déjà dans la table?

    Merci pour vos réponses

    PS : voici le message d'erreur renvoyé :
    javax.persistence.EntityExistsException: org.hibernate.exception.ConstraintViolationException: could not insert: [abaque.metier.Projet]

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

    Informations forums :
    Inscription : Juin 2007
    Messages : 383
    Par défaut
    Hibernate ne va rien faire pour t'empêcher d'essayer d'insérer un objet Projet avec le même nom qu'un projet existant.
    C'est à toi de le gérer, en catchant l'exception par exemple et en renvoyant un message clair à l'utilisateur.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Par défaut
    Très bien. C'est ce que je pensais mais j'étais pas sure.

    Merci beaucoup pour ton aide.

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Par défaut
    Encore une petite question :

    Dans le cas d'un update, l'exception n'est pas la même. Est ce normal?
    Il me renvoie cette exception :
    org.hibernate.exception.ConstraintViolationException
    Cette exception ne veut pas seulement dire que le nom existe déjà? Cela peut concerner d'autres contraintes?

    Suis je dans le vrai? et si oui dans ce cas comment le gérer? A part vérifier avant l'update.


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

    Informations forums :
    Inscription : Juin 2007
    Messages : 383
    Par défaut
    C'est la même exception

    Ca veut dire que la base a remonté une erreur de violation de contrainte.

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

Discussions similaires

  1. Architecture 3 tiers et contrainte d'unicite
    Par nkonito dans le forum ASP.NET
    Réponses: 26
    Dernier message: 07/03/2007, 20h43
  2. contrainte d'unicité fait du zèle
    Par gerald2545 dans le forum PostgreSQL
    Réponses: 7
    Dernier message: 23/02/2007, 23h12
  3. Réponses: 6
    Dernier message: 12/12/2006, 13h30
  4. gestion des contraintes d'unicité
    Par GMI3 dans le forum Oracle
    Réponses: 2
    Dernier message: 05/12/2006, 17h00
  5. contrainte d'unicité un peu spéciale....
    Par bdkiller dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 23/11/2004, 17h54

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