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 :

Problème de relation


Sujet :

JPA Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé

    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    120
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2002
    Messages : 120
    Par défaut Problème de relation
    Bonjour,

    Je n'arrive pas a trouver la bonne relation pour le diagramme suivant :


    J'ai une table Request qui est liée à la table Request_Status. Le type de relation est de 1 à 1 :

    Requests
    ID ==> PK
    ACTUAL_STATUS ==> FK vers l'id de la table Request_Status


    Request_Status
    ID ==> PK
    ID_Requests ==> FK vers id de la table Requests


    J'ai simplifié les tables.

    Au niveau des mes entité jpa j'ai donc :

    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
     
    @Entity
    @Table(name = "REQUESTS")
    public class Requests implements Serializable {
    	private Long id;
    	private RequestStatus actualStatus;
     
     
    	@Id
    	@GeneratedValue(strategy = GenerationType.IDENTITY)
    	@Column(name = "ID", updatable = true, nullable = false, insertable = true)
    	public Long getId() {
    		return this.id;
    	}
     
    	public void setId(Long id) {
    		this.id = id;
    	}
     
             //Type de relation A
             @Column(name = "ACTUAL_STATUS", updatable = true, nullable = true,
    	 * insertable = true)
    	public RequestStatus getActualStatus() {
    		return this.actualStatus;
    	}
     
    	public void setActualStatus(RequestStatus actualStatus) {
    		this.actualStatus = actualStatus;
    	}
     
     
     
    }
    Voici le code de la table request_Status
    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
     
    @Entity
    @Table(name = "REQUEST_STATUS")
    public class RequestStatus implements Serializable {
    	private Long id;
    	private Requests requests;
     
    	@Id
    	@GeneratedValue(strategy = GenerationType.IDENTITY)
    	@Column(name = "ID", updatable = true, nullable = false, insertable = true)
    	public Long getId() {
    		return this.id;
    	}
     
    	public void setId(Long id) {
    		this.id = id;
    	}
     
    	@ManyToOne(fetch = FetchType.LAZY)
    	@JoinColumn(name = "ID_REQUESTS")
    	public Requests getRequests() {
    		return this.requests;
    	}
     
    	public void setRequests(Requests requests) {
    		this.requests = requests;
    	}
     
     
    }

    le @ManytoOne semble fonctionner comme je le veux pour la classe RequestStatus par contre j'ai essayer pleins de combinaison pour le ActualStatus, mais sans succès. Avez vous une idée de quelle relation je dois faire usage ?

    je doute que se soit util mais j'utilise OpenJPA.


    merci d'avance pour votre aide

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 23
    Par défaut
    Le tag ManyToOne autorise une requête a avoir plusieurs statuts ...
    Il existe un tag One-To-One pour faire ce genre de mapping :

    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
     
    @Entity
    @Table(name = "REQUESTS")
    public class Requests implements Serializable {
    	private Long id;
    	private RequestStatus actualStatus;
     
     
    	@Id
    	@GeneratedValue(strategy = GenerationType.IDENTITY)
    	@Column(name = "ID", updatable = true, nullable = false, insertable = true)
    	public Long getId() {
    		return this.id;
    	}
     
    	public void setId(Long id) {
    		this.id = id;
    	}
     
             //Type de relation A
             @OneToOne(cascade = CascadeType.ALL, fetch=FetchType.LAZY)
             @JoinColumn(name = "ACTUAL_STATUS", unique = true, nullable = false)
    	public RequestStatus getActualStatus() {
    		return this.actualStatus;
    	}
     
    	public void setActualStatus(RequestStatus actualStatus) {
    		this.actualStatus = actualStatus;
    	}
     
     
     
    }
    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
     
    @Entity
    @Table(name = "REQUEST_STATUS")
    public class RequestStatus implements Serializable {
    	private Long id;
    	private Requests requests;
     
    	@Id
    	@GeneratedValue(strategy = GenerationType.IDENTITY)
    	@Column(name = "ID", updatable = true, nullable = false, insertable = true)
    	public Long getId() {
    		return this.id;
    	}
     
    	public void setId(Long id) {
    		this.id = id;
    	}
     
    	@OneToOne(mappedBy = "ACTUAL_STATUS", fetch=FetchType.LAZY)
    	public Requests getRequests() {
    		return this.requests;
    	}
     
    	public void setRequests(Requests requests) {
    		this.requests = requests;
    	}
     
     
    }

  3. #3
    Membre confirmé

    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    120
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2002
    Messages : 120
    Par défaut
    Merci pour ta solution, tout compte fait, j'ai fait 2 one to many et sa fonctionne très bien...

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

Discussions similaires

  1. problème de relations
    Par dolphin96 dans le forum Access
    Réponses: 3
    Dernier message: 23/07/2006, 23h24
  2. Problème de relation double
    Par Rub-n dans le forum Access
    Réponses: 1
    Dernier message: 31/05/2006, 19h07
  3. Problème de relation entre deux tables + autre chose
    Par Goth_sensei dans le forum Langage SQL
    Réponses: 7
    Dernier message: 30/03/2006, 21h49
  4. [conception] Requête de sélection problèmes de relations
    Par snoopy69 dans le forum Modélisation
    Réponses: 26
    Dernier message: 08/11/2005, 15h23
  5. Gestion club sportif (problème de relations )
    Par jemaflo dans le forum Access
    Réponses: 3
    Dernier message: 04/10/2005, 00h00

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