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 :

Mapping Enum sur une table de la base


Sujet :

JPA Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de ziad.shady
    Homme Profil pro
    Inscrit en
    Mai 2008
    Messages
    212
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Hauts de Seine (Île de France)

    Informations forums :
    Inscription : Mai 2008
    Messages : 212
    Par défaut Mapping Enum sur une table de la base
    Bonjour,

    Je souhaiterai mapper une énumération sur une table de la base. Ensuite utiliser cet enum dans un objet de persistance.

    Voici la table sur laquelle l'énumération sera mapper :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    CREATE TABLE TypeArticle
      (
        TYAR_ID INTEGER NOT NULL ,
        TYAR_CODE VARCHAR2 (6 CHAR) NOT NULL ,
        TYAR_LIBELLE VARCHAR2 (48 CHAR) NOT NULL
      ) ;
    Voici l'énumération à mapper :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    public enum TypeArticleEnum {
        ARTICLE_LONG (1, "ART_LNG", "Article long"),
        ARTICLE_COURT (2, "ART_CRT", "Article court"),
        ARTICLE_LOURD (3, "ART_LRD", "Article lourd"),
        ARTICLE_LEGER (4, "ART_LGR", "Article léger");
    }
    Dans l'objet de persistance, j'envisage quelque chose du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    @Entity
    @Table(name = "ARTICLE")
    public class Article implements Serializable {
     
    // @?
    private TypeArticleEnum typeArticle;
     
    // Guetter
    public TypeArticleEnum getTypeArticle () { return this.typeArticle; }
     
    // Setter 
    public setTypeArticle (TypeArticleEnum typeArticle) { this.typeArticle = typeArticle; }}
    N.B. Ce qui est entre parenthèse dans l'enum, correspond aux insert de la table TypeArticle.

    Questions:
    1. Par quoi il va falloir compléter l'énumération ?
    2. Quelle annotation à mettre sur l'attribut "typeArticle" ou éventuellement sur son getter?

    Un exemple est toujours le bienvenue

    Je vous remercie par avance.

  2. #2
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    Bonjour,

    Je ne vois pas l’intérêt d'utiliser un enum dans ce cas précis !
    L'objectif de l'enum est d'avoir des constantes prédéfini, or toi tu veux générer l'enum dynamiquement et donc tu ne peux pas les utiliser en tant que constantes.

    Si ce sont de vrai constante alors pourquoi les mettre en base ?
    Sinon tu peux très bien utiliser une classe classique !
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    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
    +1

    Le type "enum" est géré par défaut par jpa comme un type simple, et sera mappé sur une colonne de type char portant le nom de l'enum. Il n'y aura pas jointure.

    Vu comme tu veux faire (mettre le nom, description, etc) en base, ce ne sera pas un enum puisque jpa est amené à en créer autant qu'il n'y a de lignes dans la table :/

Discussions similaires

  1. Réponses: 0
    Dernier message: 09/09/2011, 09h49
  2. Mapping * entités sur une table
    Par istace.emmanuel dans le forum Entity Framework
    Réponses: 2
    Dernier message: 26/07/2011, 17h31
  3. [CR 8] Est-il possible de gérer les droits sur une table de la base
    Par foulla dans le forum SAP Crystal Reports
    Réponses: 0
    Dernier message: 06/01/2009, 15h16
  4. Réponses: 2
    Dernier message: 03/03/2007, 19h03
  5. Réponses: 2
    Dernier message: 07/07/2005, 08h31

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