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 :

Problème de persistence de données


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Inscrit en
    Février 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 18
    Points : 8
    Points
    8
    Par défaut Problème de persistence de données
    Bonjour à tous,

    Je développe actuellement une application JEE utilisant Hibernate, et je suis confronté à un problème qui m'étonne et me dépasse.

    Je ne fais mes tests qu'avec un seul utilisateur, ma base est sous mysql v5, j'utilise glassfish 3.0.1.

    J'ai une table nommée 'champperso', à laquelle j'ajoute une entrée via le code suivant :

    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
     
    Session session = DatabaseSessionFactory.getSession();
                    Transaction t = session.beginTransaction();
                    try {    
                        Champperso p = new Champperso();
                        p.setDescription(nom);
                        session.save(p);
                        t.commit();
                        //Enregistrement OK
                    }
                    catch(Exception e) {
                        //Erreur d'enregistrement
                        t.rollback();
                    }
                    finally {
                        session.close();
                    }
    Les données sont bien enregistrées, et les modifications sont effectuées en base.



    Ensuite, dans d'autres pages je veux charger et afficher mes champs perso.
    J'utilise alors la fonction suivante pour les récupérer :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    public static List<Champperso> loadChamppersos() {
    Session session = DatabaseSessionFactory.getSession();
             List<Champperso> result = null;
             try {
                result = session.createCriteria(Champperso.class).addOrder(Order.asc("description")).list();
             }
             finally {
                 session.close();
             }
    return result;

    Cette fonction doit me renvoyer la liste des entrées de la table champperso.

    Le problème est que si j'ouvre la page plusieurs fois d'affilées, certaines fois je vais avoir tous les champs perso, et d'autres fois j'obtiens uniquement ceux qui étaient en base au moment du déploiement de mon application.

    C'est à dire que si j'ajoute un champ perso et que j'affiche ma liste ensuite, il se peut que mon nouveau champ perso ne soit pas dans la liste.
    Je recharge la page (sans rien toucher d'autre), et cette fois il y sera. Etc.

    Je ne vois vraiment pas d'où vient ce problème, que je rencontre aussi dans d'autres tables et d'autres pages.

    La fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DatabaseSessionFactory.getSession();
    ouvre simplement une nouvelle session et me la renvoie. Je l'utilise ensuite (je pense correctement), je n'oublie pas de la fermer après utilisation.

    Toute aide serait appréciée, car je suis complètement dans une impasse.

    Merci d'avance à tous,
    Antoine.

  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 : 44
    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 807
    Points
    48 807
    Par défaut
    la seule raison pour laquelle se problème pourrait survenir c'est si vos sessions DB ne sont pas fermées, ce qui implique que les sessions d'avant l'ajoute continuent (via les principes d'isolation SERIALIZABLE de jdbc) à voir la DB dans l'état ou elle était avant l'insertion.

  3. #3
    Futur Membre du Club
    Inscrit en
    Février 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 18
    Points : 8
    Points
    8
    Par défaut
    Merci pour votre réponse !

    Le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    finally {
                        session.close();
                    }
    n'est il pas suffisant pour fermer ma session ?

    Dois-je utiliser un
    ?

  4. #4
    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 : 44
    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 807
    Points
    48 807
    Par défaut
    on peut voir le code de DatabaseSessionFactory.getSession();
    ?

  5. #5
    Futur Membre du Club
    Inscrit en
    Février 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 18
    Points : 8
    Points
    8
    Par défaut
    Voilà ma classe DatabaseSessionFactory :

    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
     
    public class DatabaseSessionFactory {
     
    private static final SessionFactory sessionFactory;
     
        static {
            try {
                    sessionFactory = new AnnotationConfiguration().configure().buildSessionFactory();
            } catch (Throwable ex) {
                System.err.println("Initial SessionFactory creation failed." + ex);
                throw new ExceptionInInitializerError(ex);
            }
        }
     
     
    public static Session getSession() {
            return sessionFactory.openSession();
        }
     
    }

  6. #6
    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 : 44
    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 807
    Points
    48 807
    Par défaut
    es-tu sur que la méthode loadChamppersos est bien appelée à chaque fois? Que tu ne cache pas en aval ces valeurs?

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 24/09/2014, 11h07
  2. [EJB3 Entity] Problème de persistence avec base de données MySQL
    Par sheridan08 dans le forum Java EE
    Réponses: 8
    Dernier message: 29/03/2013, 12h13
  3. [AJAX] XMLHttpRequest : persistance de donnée.
    Par Rapheux dans le forum AJAX
    Réponses: 3
    Dernier message: 12/12/2011, 18h02
  4. Problème de Persistance - Accès au données
    Par lezert dans le forum Développement Web en Java
    Réponses: 0
    Dernier message: 23/05/2010, 17h48
  5. problème xsl : inclure une donnée xml dans une balise html
    Par djodjo dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 03/01/2003, 09h24

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