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

Bases de données Delphi Discussion :

problème de requete


Sujet :

Bases de données Delphi

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    479
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 479
    Points : 102
    Points
    102
    Par défaut problème de requete
    Bonjour


    Dans un un query j'ai ajouté ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT DISTINCT D.CommandeN, D.NomClient, D.NFacture, D.Annee, D.TTC, D.HT, D.Commission, D.CommissionHT, D.Mois, D.Rue, D.N, D.Ville, D.CodePostal, D.NomClient2, D.Civilite, D1.Mois, D1.Annee, D1.NFacture, SUM(D.TTC), (D.TTC * 1.196) AS D."TTC * 1,196", (((D.Commission * D.TTC) * 1.196) / 100.0) AS D."Commission * TTC * 1,196"
    FROM "C:\gestion /Commission.DB" D, "mois.DB" D1
    WHERE
    (D1.Mois = D.Mois)
     AND (D1.Annee = D.Annee)
     AND (D1.NFacture = D.NFacture)
    GROUP BY D.CommandeN, D.NomClient, D.NFacture, D.Annee, D.TTC, D.HT, D.Commission, D.CommissionHT, D.Mois, D.Rue, D.N, D.Ville, D.CodePostal, D.NomClient2, D.Civilite, D1.Mois, D1.Annee, D1.NFacture
    ORDER BY D.CommandeN, D.NomClient, D.NFacture, D.Annee, D.TTC, D.HT, D.Commission, D.CommissionHT, D.Mois, D.Rue, D.N, D.Ville, D.CodePostal, D.NomClient2, D.Civilite, D1.Mois, D1.Annee, D1.NFacture
    et quand je veut l'executer il me dit que cette fonction n'est pas supportée pourquoi?

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    peut être parceque tu as mis un / au lieu d'un \ devant commission.db
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    479
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 479
    Points : 102
    Points
    102
    Par défaut
    j'ai changé et maintenant il me dit que les expressions dans le group by ne sont pas supporté

  4. #4
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Essaie comme ça

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    GROUP BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    479
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 479
    Points : 102
    Points
    102
    Par défaut
    fonctionnalité non supportée

  6. #6
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Je pense savoir pourquoi, j'avais pas fait gaffe a comment tu avais écrit les expressions (qu'il faut aussi rajouter dans le group by)

    Essai comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT DISTINCT D.CommandeN, D.NomClient, D.NFacture, D.Annee, D.TTC, D.HT, D.Commission, D.CommissionHT, D.Mois, D.Rue, D.N, D.Ville, D.CodePostal, D.NomClient2, D.Civilite, D1.Mois, D1.Annee, D1.NFacture, SUM(D.TTC), (D.TTC * 1.196) AS "TTC * 1,196", (((D.Commission * D.TTC) * 1.196) / 100.0) AS "Commission * TTC * 1,196"
    FROM "C:\gestion\Commission.DB" D, "mois.DB" D1
    WHERE
    (D1.Mois = D.Mois)
     AND (D1.Annee = D.Annee)
     AND (D1.NFacture = D.NFacture)
    GROUP BY D.CommandeN, D.NomClient, D.NFacture, D.Annee, D.TTC, D.HT, D.Commission, D.CommissionHT, D.Mois, D.Rue, D.N, D.Ville, D.CodePostal, D.NomClient2, D.Civilite, D1.Mois, D1.Annee, D1.NFacture,20,21
    ORDER BY D.CommandeN, D.NomClient, D.NFacture, D.Annee, D.TTC, D.HT, D.Commission, D.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    479
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 479
    Points : 102
    Points
    102
    Par défaut
    fonctionnalité non supporté

  8. #8
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Le mieux a faire est de virer dans un premier temps les champs calculés de ta requête et de tester.
    Après tu testes en rajoutant les Champs calculés un à un et tu regardes sur lequel ca plante.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  9. #9
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    479
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 479
    Points : 102
    Points
    102
    Par défaut
    C'est bien mes champs calculé qui me foute le souc à tu une idée?

  10. #10
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Salut,

    A mon avis il faut que tu répètes dans le group by les deux expressions de tes champs calculés.

    @+

  11. #11
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Que tu les enlèves de la requetes et que tu les calcules au niveau de l'affichage aux champs calculés.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  12. #12
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Citation Envoyé par Claudius40
    Salut,

    A mon avis il faut que tu répètes dans le group by les deux expressions de tes champs calculés.

    @+
    Dans la version que je l'ui ai fournit de ca requete je l'ai fait (20 et 21 dans le Group By)
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  13. #13
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Citation Envoyé par Malatar
    Dans la version que je l'ui ai fournit de ca requete je l'ai fait (20 et 21 dans le Group By)
    Exact Malatar, en théorie ça devrait fonctionner !
    @+

  14. #14
    Membre du Club
    Inscrit en
    Juillet 2002
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 84
    Points : 67
    Points
    67
    Par défaut
    Bonjour,

    Le schéma du GROUP BY n'est pas compatible avec le schéma du SELECT, il faut retirer les 2 derniers champs calculés.

    Que veux-tu faire ?

    ..., SUM(D.TTC), (D.TTC * 1.196) AS "TTC * 1,196", ...
    1°) (D.TTC * 1.196) fait référence à SUM(D.TTC) auquel cas cela ne peut pas fonctionner tel quel. Il faudra renomer tes deux champs et exécuter un select imbriqué, une vue ou une procédure stockée au choix pour un traitement par le SGBD ou sinon écrire du code pour traiter l'info.

    2°) (D.TTC * 1.196) fait référence à D.TTC auquel cas tu vas perdre des infos car le GROUP BY, comme son nom l'indique, regroupe les lignes et donc n'affiche qu'une seule ligne par groupe de lignes ayant toutes les mêmes valeurs respectivements dans les champs désignés dans le GROUP BY en commun.

    Cyril

  15. #15
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    bien vu cgone, en fait s'il veut avoir un résultat de la somme TTC * 1.196 et de son autre calcul il faut

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ...,(Sum(D.TTC) * 1.196) AS "TTC * 1,196", (((D.Commission * Sum(D.TTC)) * 1.196) / 100.0) AS "Commission * TTC * 1,196"
    Je pense que c'est plus ce qu'il attend
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  16. #16
    Membre du Club
    Inscrit en
    Juillet 2002
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 84
    Points : 67
    Points
    67
    Par défaut
    Tu as raison Malatar, pourquoi faire compliqué quand on peut faire simple...

    Cyril.

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

Discussions similaires

  1. [EJBQL] Problème de requete
    Par rivierem dans le forum Java EE
    Réponses: 3
    Dernier message: 16/10/2004, 10h05
  2. Problème sous requete MySQL
    Par gavelin dans le forum Langage SQL
    Réponses: 3
    Dernier message: 20/07/2004, 10h36
  3. Problème de Requete...
    Par sebiv dans le forum Langage SQL
    Réponses: 6
    Dernier message: 29/04/2004, 16h21
  4. Problème de requete avec Innodb
    Par silef dans le forum Requêtes
    Réponses: 3
    Dernier message: 14/04/2004, 12h54
  5. Problème de requete multis-selections
    Par tripper.dim dans le forum SQL
    Réponses: 9
    Dernier message: 03/09/2003, 13h08

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