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 :

récuperation de données


Sujet :

Hibernate Java

  1. #1
    Membre régulier
    Inscrit en
    Mars 2008
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 109
    Points : 99
    Points
    99
    Par défaut récuperation de données
    bonjour a tous,

    je débute sur hibernate et mon pb est le suivant:

    j'ai une table expérience professionnelle qui a une relation one to many avec les tables typologieMission,client,cv,projet,poste.

    mon souci c'est quant je récupère un objet expérience professionnelle j'arrive pas a acceder aux objets typologieMission,client ,ect

    voici mon fichier ExperienceProfessionnelle.hbm.xml

    merci pour votre aide.
    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
    <hibernate-mapping package="skills.cv.rubrique">
        <class name="ExperienceProfessionnelle" table="experienceprofessionnelle" schema="public">
            <id name="idExperienceProfessionnelle" type="int">
                <column name="idexperienceprofessionnelle" />
                <generator class="sequence" >
                <param name="sequence">experienceprofessionnelle_idexperienceprofessionnelle_seq</param>
                </generator>
            </id>
            <many-to-one name="typologieMission" class="skills.referentiel.TypologieMission"  fetch="select">
                <column name="idTypologieMission" not-null="true" />
            </many-to-one>
            <many-to-one name="client" class="skills.referentiel.Client" fetch="select">
                <column name="idClient" not-null="true" />
            </many-to-one>
            <many-to-one name="cv" class="skills.cv.Cv" fetch="select">
                <column name="cv_idcv" not-null="true" />
            </many-to-one>
            <many-to-one name="projet" class="skills.referentiel.Projet" fetch="select">
                <column name="projet_idprojet" not-null="true" />
            </many-to-one>
            <many-to-one name="poste" class="skills.referentiel.Poste" fetch="select">
                <column name="idposte" not-null="false" />
            </many-to-one>
            <property name="dateDebut" type="date">
                <column name="datedebut" length="13" not-null="true" />
            </property>
            <property name="dateFin" type="date">
                <column name="datefin" length="13" />
            </property>
            <property name="duree" type="java.lang.Integer">
                <column name="duree" />
            </property>
            <property name="description" type="string">
                <column name="description" />
            </property>
            <property name="ville" type="string">
                <column name="ville" />
            </property>
            <property name="referent" type="string">
                <column name="referent" />
            </property>
            <property name="service" type="string">
                <column name="service" />
            </property>        
            <property name="datemaj" type="date">
                <column name="datemaj" length="13" />
            </property>
     
            <set name="simplesCompetences" table="ExperienceProfessionnelle_has_SimpleCompetence">
                <key>
                    <column name="idExperienceProfessionnelle" not-null="true" />
                </key>
                <many-to-many entity-name="skills.cv.rubrique.SimpleCompetence">
                    <column name="idSimpleCompetence" not-null="true" />
                </many-to-many>
            </set>
        </class>
    </hibernate-mapping>

  2. #2
    Expert éminent sénior
    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 : 45
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 804
    Points
    48 804
    Par défaut
    Qu'est-ce que tu veux dire par "j'arrive pas a acceder aux objets typologieMission,client ,ect ", message d'erreur, stacktrace, ?

  3. #3
    Membre régulier
    Inscrit en
    Mars 2008
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 109
    Points : 99
    Points
    99
    Par défaut
    salut merci pour votre reponse.

    je veux dire par "je n'arrive pas a y accéder" c'est quant j'instanciée un objet expérience professionnelle et que je fais par exemple un test

    System.out.println("test" + listeExperiences.get(i).getPoste().getLibellePoste());
    ca ne m'affiche rien et ca me donne la trace suivante

    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
    org.hibernate.LazyInitializationException: could not initialize proxy - the owning Session was closed
            at org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:60)
            at org.hibernate.proxy.AbstractLazyInitializer.getImplementation(AbstractLazyInitializer.java:111)
            at org.hibernate.proxy.pojo.cglib.CGLIBLazyInitializer.invoke(CGLIBLazyInitializer.java:140)
            at skills.referentiel.Poste$$EnhancerByCGLIB$$83631c47.getLibellePoste(<generated>)
            at skills.cv.ViewCVBean.getXMLCv(ViewCVBean.java:166)
            at skills.cv.ExportCVServlet.processRequest(ExportCVServlet.java:36)
            at skills.cv.ExportCVServlet.doGet(ExportCVServlet.java:59)
            at javax.servlet.http.HttpServlet.service(HttpServlet.java:690)
            at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
            at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
            at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
            at org.apache.shale.application.faces.ShaleApplicationFilter.doFilter(ShaleApplicationFilter.java:267)
            at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
            at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
            at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:390)
            at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
            at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
            at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
            at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
            at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:525)
            at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
            at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
            at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
            at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:263)
            at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
            at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:584)
            at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
            at java.lang.Thread.run(Thread.java:619)
    par contre si je fais
    System.out.println("test " + listeExperiences.get(i).getDescription());
    ce me l'affiche corectement.

    merci pour votre aide.

  4. #4
    Membre régulier
    Inscrit en
    Mars 2008
    Messages
    109
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 109
    Points : 99
    Points
    99
    Par défaut
    salut, pour ceux que ça peu intéresser il faller rajouter lazy="false"



    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
    <hibernate-mapping package="skills.cv.rubrique">
        <class name="ExperienceProfessionnelle" table="experienceprofessionnelle" schema="public">
            <id name="idExperienceProfessionnelle" type="int">
                <column name="idexperienceprofessionnelle" />
                <generator class="sequence" >
                <param name="sequence">experienceprofessionnelle_idexperienceprofessionnelle_seq</param>
                </generator>
            </id>
            <many-to-one name="typologieMission" class="skills.referentiel.TypologieMission"  fetch="select" lazy="false">
                <column name="idTypologieMission" not-null="true" />
            </many-to-one>
            <many-to-one name="client" class="skills.referentiel.Client" fetch="select" lazy="false">
                <column name="idClient" not-null="true" />
            </many-to-one>
            <many-to-one name="cv" class="skills.cv.Cv" fetch="select" lazy="false">
                <column name="cv_idcv" not-null="true" />
            </many-to-one>
            <many-to-one name="projet" class="skills.referentiel.Projet" fetch="select" lazy="false">
                <column name="projet_idprojet" not-null="true" />
            </many-to-one>
            <many-to-one name="poste" class="skills.referentiel.Poste" fetch="select" lazy="false">
                <column name="idposte" not-null="false" />
            </many-to-one>
            <property name="dateDebut" type="date">
                <column name="datedebut" length="13" not-null="true" />
            </property>
            <property name="dateFin" type="date">
                <column name="datefin" length="13" />
            </property>
            <property name="duree" type="java.lang.Integer">
                <column name="duree" />
            </property>
            <property name="description" type="string">
                <column name="description" />
            </property>
            <property name="ville" type="string">
                <column name="ville" />
            </property>
            <property name="referent" type="string">
                <column name="referent" />
            </property>
            <property name="service" type="string">
                <column name="service" />
            </property>        
            <property name="datemaj" type="date">
                <column name="datemaj" length="13" />
            </property>
     
            <set name="simplesCompetences" table="ExperienceProfessionnelle_has_SimpleCompetence">
                <key>
                    <column name="idExperienceProfessionnelle" not-null="true" />
                </key>
                <many-to-many entity-name="skills.cv.rubrique.SimpleCompetence">
                    <column name="idSimpleCompetence" not-null="true" />
                </many-to-many>
            </set>
        </class>
    </hibernate-mapping>

  5. #5
    Expert éminent sénior
    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 : 45
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Points : 48 804
    Points
    48 804
    Par défaut
    the owning Session was closed
    Soit comme tu l'as fait, on met le lazy à false (attentions aux risque de charger en cascade tout la db pour récupérer un simple objet), soit on ne ferme pas la session hibbernate tant qu'on en a pas fini avec l'objet (méthode recommandée pour pouvoir utiliser le lazy loading et donc décharger un peu la mémoire)

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

Discussions similaires

  1. Récuperer les données d'un FlexGrid pour faire requete SQL
    Par Terminator dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 13/10/2005, 11h26
  2. Récupere les données d'un dataGrid
    Par Terminator dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 11/10/2005, 14h05
  3. [JTable] Comment récuperer les données d'un fichier texte ?
    Par Makunouchi dans le forum Composants
    Réponses: 2
    Dernier message: 03/05/2005, 16h37
  4. Réponses: 5
    Dernier message: 22/12/2004, 16h13
  5. Comment récuperer des données entrées au clavier?
    Par Elisée A. dans le forum MFC
    Réponses: 2
    Dernier message: 13/02/2004, 07h22

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