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 :

Hibernate : pb group by


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    188
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 188
    Par défaut Hibernate : pb group by
    Bonjour,
    J'ai dans mon code ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Session hibernateSession = SQLConnexion.currentSession();
    			list = hibernateSession.find("SELECT count(*) FROM Evolution e");
    Cette requete marche correctement mais lorsque je modifie la requete comme ceci, le programme refuse de l'exécuter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Session hibernateSession = SQLConnexion.currentSession();
    			list = hibernateSession.find("SELECT count(*), e.ID_ETAT FROM Evolution e group by e.ID_ETAT");
    Pourtant, j'ai exécuté cette requete dans PHPMyAdmin et celle ci fonctionne.

    Comprenez vous pourquoi?

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    188
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 188
    Par défaut
    Zut alors, personne ne peut m'aider?

  3. #3
    Membre Expert
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Par défaut
    Salut, il ne faudrait pas utiliser la méthode createSQLQuery plutôt que find ?

  4. #4
    zev
    zev est déconnecté
    Membre expérimenté
    Inscrit en
    Octobre 2004
    Messages
    204
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 204
    Par défaut
    e.ID_ETAT
    Par convention ID_ETAT serait un nom de table et le nom de l'objet, utilisé par hibernate devrait etre plutot du style idEtat.

    Vérifie le nom que tu as donné à ta table dans ton mapping hibernate, et remplace ID_ETAT par ce nom si j'ai vu juste

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    163
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 163
    Par défaut
    Ne pas confondre les requêtes en SQL -> noms en tables, colonnes...
    de celles en HQL -> noms objets, attributs d'objets...

    Dans la méthode find, c'est en objet qu'il faut que tu exprime ta requête !

  6. #6
    Membre Expert
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Par défaut
    Citation Envoyé par cicolas
    Ne pas confondre les requêtes en SQL -> noms en tables, colonnes...
    de celles en HQL -> noms objets, attributs d'objets...

    Dans la méthode find, c'est en objet qu'il faut que tu exprime ta requête !
    D'où le createSQLQuery plutôt que find

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 62
    Par défaut
    Citation Envoyé par clairette
    Bonjour,
    J'ai dans mon code ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Session hibernateSession = SQLConnexion.currentSession();
    			list = hibernateSession.find("SELECT count(*) FROM Evolution e");
    Cette requete marche correctement mais lorsque je modifie la requete comme ceci, le programme refuse de l'exécuter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Session hibernateSession = SQLConnexion.currentSession();
    			list = hibernateSession.find("SELECT count(*), e.ID_ETAT FROM Evolution e group by e.ID_ETAT");
    Pourtant, j'ai exécuté cette requete dans PHPMyAdmin et celle ci fonctionne.

    Comprenez vous pourquoi?

    Il me semble tout simplemet que tu ne peux pas utiliser des fonctions des groupe (GROUP BY), avec des requetes single Row (count(*)).

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    163
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 163
    Par défaut
    Une syntaxe du genre, ça peut chtète d'aider :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Integer maxAn = (Integer) s.createSQLQuery(
    "select max(liv.annee) as maxAnnee from Livres liv").addScalar ("maxAnnee", Hibernate.INTEGER).uniqueResult();
    System.out.println("Année maximale présente : " + maxAn);

Discussions similaires

  1. [hibernate] requete avec des group by
    Par xavier_ dans le forum Hibernate
    Réponses: 1
    Dernier message: 17/11/2008, 10h18
  2. [Hibernate 3] Group by
    Par Kyuden dans le forum Hibernate
    Réponses: 4
    Dernier message: 25/05/2007, 11h44
  3. Traiter un groupe de requêtes avec Hibernate
    Par barouz dans le forum Hibernate
    Réponses: 1
    Dernier message: 20/04/2007, 16h11
  4. gestion des groupes
    Par muaddib dans le forum QuickReport
    Réponses: 3
    Dernier message: 31/12/2002, 11h01

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