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 :

Problème : Repeated column in mapping for entity


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
    Septembre 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 110
    Par défaut Problème : Repeated column in mapping for entity
    Bonjour,

    J'ai un problème :

    Repeated column in mapping for entity: com.anathec.business.Dose column: id_product (should be mapped with insert="false" update="false")

    Voici mes tables :



    Et mon code :

    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
     
    @Entity
    @Table(name = "dose", catalog = "anathec")
    public class Dose implements Serializable {
     
        private DoseId id;
        private Product product;
        private ProductConcentration productConcentration;
        private double dailyProductDose;
     
        public Dose() {
        }
     
        @EmbeddedId
        @AttributeOverrides({
           @AttributeOverride(name = "idProduct", column = @Column(name = "id_product", nullable = false)) })
        public DoseId getId() {
       return this.id;
        }
     
        public void setId(DoseId id) {
       this.id = id;
        }
     
        @ManyToOne(fetch = FetchType.EAGER)
        @JoinColumn(name = "id_product", nullable = false, insertable = false, updatable = false)
        public Product getProduct() {
       return this.product;
        }
     
        public void setProduct(Product product) {
       this.product = product;
        }
     
        @ManyToOne(fetch = FetchType.EAGER)
        @JoinColumns({
           @JoinColumn(name = "id_product", referencedColumnName = "id_product", nullable = false),
           @JoinColumn(name = "id_product_concentration", referencedColumnName = "id_product_concentration", nullable = false) })
        public ProductConcentration getProductConcentration() {
       return this.productConcentration;
        }
     
        public void setProductConcentration(ProductConcentration productConcentration) {
       this.productConcentration = productConcentration;
        }
     
        @Column(name = "daily_product_dose", nullable = false, precision = 22, scale = 0)
        public double getDailyProductDose() {
       return this.dailyProductDose;
        }
     
        public void setDailyProductDose(double dailyProductDose) {
       this.dailyProductDose = dailyProductDose;
        }
    }
    J'ai un peu simplifier l'objet pour que ce soir plus compréhensible.

    Comment faire pour avoir le résultat voulus comme dans le graph?

    Merci,

  2. #2
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    c'est quoi cette classe DoseId?

    A quoi sert ton @AttributesOverride? Tu n'étends aucun classe!

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 110
    Par défaut
    DoseId, c'est ma clé composé. On ne le voit pas ici car j'ai simplifié l'objet pour le forum mais sinon ça donne ça :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
        @EmbeddedId
        @AttributeOverrides({
    	    @AttributeOverride(name = "idCharge", column = @Column(name = "id_charge", nullable = false)),
    	    @AttributeOverride(name = "idPatient", column = @Column(name = "id_patient", nullable = false)),
    	    @AttributeOverride(name = "idProduct", column = @Column(name = "id_product", nullable = false)) })
        public DoseId getId() {
    	return this.id;
        }

  4. #4
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    tu va devoir remplacer ton get/setProduct par quelque chose du style

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public Product getProduct(){
       return getId().getProduct();
    }
    Pareil pour les autres liaisons. Une colonne ne peux être mappée qu'une seule fois et comme tu mappe les trois colonnes formant la clé dans DoseId, les propriétés qui en dépendent doivent passer par ce DoseId.

  5. #5
    Membre éprouvé
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Décembre 2005
    Messages
    109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Décembre 2005
    Messages : 109
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        @ManyToOne(fetch = FetchType.EAGER)
        @JoinColumns({
           @JoinColumn(name = "id_product", referencedColumnName = "id_product", nullable = false),
           @JoinColumn(name = "id_product_concentration", referencedColumnName = "id_product_concentration", nullable = false) })
        public ProductConcentration getProductConcentration() {
       return this.productConcentration;
        }
    Ajouter un "insertable = false, updatable = false" ici ne suffirait-il pas ? (Je ne connais pas bien les mappings par annotation ...)

    Par expérience, avoir des objets complexes dans une clé composée n'est pas une bonne idée. Donc je ne conseille pas d'avoir l'objet Product dans l'objet DoseId.
    Ça pose par exemple des problèmes quand on commence à jouer avec un cache et qu'on ne fait pas attention à la sérialisation de la clé.

  6. #6
    Membre Expert
    Inscrit en
    Août 2009
    Messages
    1 073
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 1 073
    Par défaut
    Mettre "update=false" et "insert=false" suffit normalement à pouvoir mapper en double la colonne.
    Cela dit, je plussoie Tchize : c'est nettement plus propre de prendre la propriété de l'id.
    Quant à la clé composite, du moment qu'elle est déclarée en classe séparée avec les méthodes hashCode et equals proprement redéfinies, il n'y a pas de souci.

Discussions similaires

  1. Réponses: 1
    Dernier message: 23/06/2014, 15h04
  2. Réponses: 3
    Dernier message: 12/08/2011, 09h17
  3. Réponses: 0
    Dernier message: 11/11/2009, 01h29
  4. Repeated column in mapping for entity
    Par franchouze dans le forum Hibernate
    Réponses: 1
    Dernier message: 08/10/2009, 09h51
  5. [VB6] Problème contrôle Timer et boucle For-Next ...
    Par Stéphane BEHMENBURG dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 01/12/2005, 17h36

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