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

JPA Java Discussion :

PrimaryKey, ForeignKey composites et collections


Sujet :

JPA Java

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5
    Points : 6
    Points
    6
    Par défaut PrimaryKey, ForeignKey composites et collections
    Bon, je ne savais pas trop comment nommer mon post car voici mon probleme :

    Imaginons tableA, comportant une clef primaire composite avec champA et champB
    Imaginons maintenant tableB, avec une clef primaire composite constituée de champA, champB, champC
    Les élements de tableB liés à un élément de tableA sont donc facilement récupérables, suffit de selectionner sur les deux champs champA et champB.

    Maintenant, partant du principe que ce schema NE PEUT ETRE modifié, comment dois je mapper tableA et tableB de telle sorte que ObjetA ait :
    - sa clef composite constituée de deux attributs
    - une collection d'ObjetB

    et de telle sorte que ObjetB ait :
    - sa clef composite consituée de ses trois attributs
    - une référence (ManyToOne) vers ObjetA, laquelle met en jeu deux des attributs de sa clef primaire composite...

    Je tourne en rond depuis un jour sans succès... et ce parce que le lien entre les deux objets repose sur des colonnes qui sont dejà "utilisées" pour la clef primaire composite d'objetB...

    D'avance merci

  2. #2
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5
    Points : 6
    Points
    6
    Par défaut
    Avez vous remarqué comme des fois il suffit de parler à quelqu'un d'un problème pour avoir de nouvelles pistes qui viennent à l'esprit ?

    Et bien cela fonctionne aussi avec les forums !

    Voici donc la réponse à mon problème qui du coup n'en est plus un :

    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
    @Entity
    ObjetA {
    	@EmbeddedId
    	private ObjetAKey objAKey;
    
    	@OneToMany(cascade=CascadeType.ALL)
    	@JoinColumns({
    		@JoinColumn(name="CHAMPA", referencedColumnName="CHAMPA"),
    		@JoinColumn(name="CHAMPB", referencedColumnName="CHAMPB")
    	})
    	private Set<ObjetB> objetsB;
    }
    
    @Entity
    ObjetB {
    
    	@EmbeddedId
    	private ObjetBKey objBKey;
    
    	@ManyToOne
    	@JoinColumns({
    		@JoinColumn(name="CHAMPA", referencedColumnName="CHAMPA", insertable=false, updatable=false),
    		@JoinColumn(name="CHAMPB", referencedColumnName="CHAMPB", insertable=false, updatable=false)
    	})
    	private ObjetA objetA;
    
    }
    La "clef" de la réussite tenait "juste" à insertable=false, updatable=false coté ManyToOne... et en plus c'est dans la doc dirait l'autre...

    Merci pour votre écoute en tous cas, ça m'a aidé ! ;-)

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

Discussions similaires

  1. [Composite] composite ou collection
    Par nebul dans le forum Design Patterns
    Réponses: 1
    Dernier message: 02/04/2013, 00h15
  2. [2.x] validation collection composite keys
    Par symfony_dev dans le forum Symfony
    Réponses: 0
    Dernier message: 10/05/2012, 23h01
  3. Réponses: 1
    Dernier message: 12/04/2010, 18h16
  4. Réponses: 8
    Dernier message: 16/01/2007, 12h16
  5. [VB6] Modifier la clé d'un élément d'une collection
    Par Ricou13 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 21/11/2002, 15h49

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