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 :

question de mapping ?


Sujet :

Hibernate Java

  1. #1
    Membre confirmé
    Inscrit en
    Avril 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 143
    Par défaut question de mapping ?
    J'aimerais savoir si ce mapping est correct parce que j'ai des erreurs par la suite.
    2 tables (ds ma bdd):
    Tabless Champs
    ----------- ----------
    idTable int idChamp int
    nomTable String nomChamp String
    idTable int

    Donc plusieurs champs possible pour une table mais un champs n'appartient qu'à une seule table.

    Tabless.hbm.xml :
    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
     
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
     
    <hibernate-mapping package="commun.Dao">
      <class name="Tabless" table="tabless" optimistic-lock="none">
        <id name="idTable" type="integer" unsaved-value="null">
          <column name="idTable" not-null="true" unique="true" index="PRIMARY"/>
          <generator class="native"/>
        </id>
        <property name="nomTable" type="string" column="nomTable" length="25" not-null="true"/>
        <property name="idBdd" type="integer" column="idBdd"/>
    	<set name="champs" inverse="true" cascade="all-delete-orphan" >
    	 	<key column="table"/>
            <one-to-many class="Champs" />
    	</set>
      </class>
    </hibernate-mapping>
    Champs.hbm.xml :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
     
    <hibernate-mapping package="commun.Dao">
      <class name="Champs" table="champs" optimistic-lock="none">
        <id name="idChamp" type="integer" unsaved-value="null">
          <column name="idChamp" not-null="true" unique="true" index="PRIMARY"/>
          <generator class="native"/>
        </id>
        <property name="nomChamp" type="string" column="nomChamp" length="25" not-null="true"/>
        <many-to-one name="table" class="Tabless" not-null="true"   />
      </class>
    </hibernate-mapping>
    Les fichiers java :
    Tabless.java
    // attributs
    private int idTable;
    private String nomTable;

    // associations
    private Set champs;

    Champs.java
    // attributs
    private int idChamp;
    private String nomChamp;

    // associations
    private Table table;

    Je ne mets pas les accesseurs.

    est-ce correct ?
    merci pour vos réponses.

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    548
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 548
    Par défaut
    Pour moi c'est correct oui

  3. #3
    Membre confirmé
    Inscrit en
    Avril 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 143
    Par défaut
    une question que je me pose maintenant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <set name="champs" inverse="true" cascade="all-delete-orphan" >
    	 	<key column="table"/>
            <one-to-many class="Champs" />
    a quoi correspond l'attribut "key column="table"/>" ?

  4. #4
    Membre Expert Avatar de willoi
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    1 355
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 355
    Par défaut
    Selon la doc Hibernate chapitre 6.2.1 :

    Les instances d'une collection sont distinguées dans la base par la clef étrangère de l'entité qui possède la collection. Cette clef étrangère est référencée comme la(es) colonne(s) de la clef de la collection de la table de la collection. La colonne de la clef de la collection est mappée par l'élément <key>.

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 143
    Par défaut
    dans mon cas c'est la table 'champs' qui a une clé étrangère de la table 'tabless', mais c'est 'tabless' qui possède une collection de 'champs' ?

  6. #6
    Membre Expert Avatar de willoi
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    1 355
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 355
    Par défaut
    Comme tu l'as defini oui.

  7. #7
    Membre confirmé
    Inscrit en
    Avril 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 143
    Par défaut
    A quoi correspond "key column="table"/>" dans la bdd ?

  8. #8
    Membre Expert Avatar de willoi
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    1 355
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 355
    Par défaut
    Cela correspond au nom la clef etrangere de ta collection.
    Certainement celle que tu as defini dans l'autre mapping.

  9. #9
    Membre confirmé
    Inscrit en
    Avril 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 143
    Par défaut
    d'accord donc on doit avoir 'table' là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <set name="champs" inverse="true" cascade="all-delete-orphan" >
    	 	<key column="table"/>
            <one-to-many class="Champs" />
    et là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <many-to-one name="table" class="Tabless" not-null="true"   />
    si j'ai bien compris pour que le l'association soit faite correctement ?

  10. #10
    Membre Expert Avatar de willoi
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    1 355
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 355
    Par défaut
    Oui c'est ca.

  11. #11
    Membre confirmé
    Inscrit en
    Avril 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 143
    Par défaut
    j'ai fait des tests, si je fais une simple requête :
    ca fonctionne, mais j'ai besoin de faire une jointure :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    from commun.Dao.Tabless t, commun.Dao.Bdds bd where nomBdd LIKE 'bd1'AND bd.idBdd=t.idBdd
    et j'obtiens le message d'erreur suivant :
    javax.servlet.ServletException: could not resolve property: idBdd of: commun.Dao.Tabless [from commun.Dao.Tabless t, commun.Dao.Bdds bd where nomBdd LIKE 'bd1'AND bd.idBdd=t.idBdd]
    org.apache.struts.action.RequestProcessor.processException(RequestProcessor.java:545)
    org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:486)
    org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:274)
    org.apache.struts.action.ActionServlet.process(ActionServlet.java:1482)
    org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:525)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:709)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
    je ne sais quoi faire ?

  12. #12
    Membre Expert Avatar de willoi
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    1 355
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 355
    Par défaut
    fais voir le code de commun.Dao.Bdds et de commun.Dao.Tabless
    manifestement idBdd n'est pas defini.

  13. #13
    Membre confirmé
    Inscrit en
    Avril 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 143
    Par défaut
    Voici les codes :
    commun.Dao.Bdds :
    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
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
     
    package commun.Dao;
     
    import java.util.*;
     
    public class Bdds {
     
    	private Integer idBdd;
    	private String nomBdd;
    	private String adresseIp;
    	private String numeroPort;
    	private String login;
    	private String password;
    	private String driver;
     
    	private Projets projets;
    	private Set<Tabless> tabless = new HashSet<Tabless> ();
     
     
    	public Bdds() {
    		super();
    	}
     
    	public boolean equals(Object value) {
    		//TODO Implement equals() using Business key equality.	
    		return super.equals(value);
    	}
     
     
    	public int hashCode() {
    		//TODO Implement hashCode() using Business key equality.	
    		return super.hashCode();
    	}
     
     
    	public String toString() {
    		//TODO Implement toString().	
    		return super.toString();
    	}
     
     
    	public Integer getIdBdd() {
    		return this.idBdd;
    	}
     
     
    	public void setIdBdd(Integer value) {
    		this.idBdd = value;
    	}
     
     
    	public String getNomBdd() {
    		return this.nomBdd;
    	}
     
     
    	public void setNomBdd(String value) {
    		this.nomBdd = value;
    	}
     
     
    	public String getAdresseIp() {
    		return this.adresseIp;
    	}
     
     
    	public void setAdresseIp(String value) {
    		this.adresseIp = value;
    	}
     
     
    	public String getNumeroPort() {
    		return this.numeroPort;
    	}
     
     
    	public void setNumeroPort(String value) {
    		this.numeroPort = value;
    	}
     
     
    	public String getLogin() {
    		return this.login;
    	}
     
     
    	public void setLogin(String value) {
    		this.login = value;
    	}
     
    	public String getPassword() {
    		return this.password;
    	}
     
    	public void setPassword(String value) {
    		this.password = value;
    	}
     
     
    	public String getDriver() {
    		return this.driver;
    	}
     
    	public void setDriver(String value) {
    		this.driver = value;
    	}
     
    	public Set<Tabless> getTabless() {
    		return tabless;
    	}
    	public void setTabless(Set<Tabless> tabless) {
    		this.tabless = tabless;
    	}
     
    	public Projets getProjets() {
    		return projets;
    	}
    	public void setProjets(Projets projets) {
    		this.projets = projets;
    	}
     
    }
    commun.Dao.Tabless :
    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
    56
    57
    58
    59
    60
    61
    62
    63
    64
     
    package commun.Dao;
     
    import java.util.*;
     
     
    public class Tabless {
     
    	private Integer idTable;
    	private String nomTable;
     
    	private Bdds bdds;
    	private Set<Champs> champs = new HashSet<Champs> ();
     
    	public Tabless() {
    		super();
    	}
     
    	public boolean equals(Object value) {
    		//TODO Implement equals() using Business key equality.	
    		return super.equals(value);
    	}
     
    	public int hashCode() {
    		//TODO Implement hashCode() using Business key equality.	
    		return super.hashCode();
    	}
     
    	public String toString() {
    		//TODO Implement toString().	
    		return super.toString();
    	}
     
    	public Integer getIdTable() {
    		return this.idTable;
    	}
     
    	public void setIdTable(Integer value) {
    		this.idTable = value;
    	}
     
    	public String getNomTable() {
    		return this.nomTable;
    	}
     
    	public void setNomTable(String value) {
    		this.nomTable = value;
    	}
     
    	public Bdds getBdds() {
    		return bdds;
    	}
    	public void setBdds(Bdds bdds) {
    		this.bdds = bdds;
    	}
     
    	public Set<Champs> getChamps() {
    		return champs;
    	}
    	public void setChamps(Set<Champs> champs) {
    		this.champs = champs;
    	}
     
    }

  14. #14
    Membre Expert Avatar de willoi
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    1 355
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 355
    Par défaut
    Tu ecris t.idBdd dans ta requete. Mais ta propriete idBdd n'existe pas dans ta classe Tabless.

Discussions similaires

  1. Question Theorique Map
    Par domino313131 dans le forum APIs Google
    Réponses: 0
    Dernier message: 06/06/2011, 10h49
  2. Questions Shadow Mapping
    Par supermael dans le forum OpenGL
    Réponses: 7
    Dernier message: 02/07/2010, 04h26
  3. Questions Google Maps
    Par danathane dans le forum Services
    Réponses: 1
    Dernier message: 05/03/2009, 10h53
  4. question sur mapping
    Par clairette dans le forum Hibernate
    Réponses: 5
    Dernier message: 04/07/2006, 17h10
  5. Questions sur les Map
    Par djobanaille dans le forum C++
    Réponses: 3
    Dernier message: 12/12/2005, 09h41

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