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

Langage SQL Discussion :

Fonction COUNT nombre de lignes


Sujet :

Langage SQL

  1. #21
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Bein déjà en prenant 1 jours ou 2 pour lire les tutos que vous n'avez pas compris, puis en faisant des tests.

    Ensuite revenez avec des essais si vous n'y arrivez toujours pas.

  2. #22
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    J'ai essayé avec ce code dans un premier temps pour me familiariser :
    J'ai un soucis sur l'extraction des 2 derniers caractères de la colonne MOTIF:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
        SELECT DAT, 
        sum(CASE MOTIF WHEN (SUBSTRING(MOTIF FROM 7 FOR 8))'JP'  THEN 1 ELSE 0 END) AS JOUR, 
        sum(CASE MOTIF WHEN (SUBSTRING(MOTIF FROM 7 FOR 8))'NP'THEN 1 ELSE 0 END) AS NUIT 
        FROM  S6PACTI 
        WHERE  EXTRACT(MONTH FROM DAT) = 5
        GROUP BY DAT

  3. #23
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Recherchez dans la doc de votre SGBD comment fonctionne le substring

  4. #24
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Sous Oracle, c'est la fonction SUBSTR qui doit être utilisée.
    ~ Lola ~

  5. #25
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    Je suis sous oracle, j'ai essayé ceci mais sans résultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT DAT,MOTIF 
        sum(CASE MOTIF WHEN SUBSTR( MOTIF, 7, 2)='JP'  THEN 1 ELSE 0 END) AS JOUR, 
        sum(CASE MOTIF WHEN SUBSTR( MOTIF, 7, 2)='NP' THEN 1 ELSE 0 END) AS NUIT 
        FROM  S6PACTI 
        WHERE  EXTRACT(MONTH FROM DAT) = 5
        GROUP BY DAT,MOTIF;

  6. #26
    Membre chevronné
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Points : 1 878
    Points
    1 878
    Par défaut
    Ca fait un peu trop assistanat ce topic...

    Avant d'écrire une fonction Oracle, renseignez-vous sur sa syntaxe, ses paramètres, etc...
    Ensuite, quelle est l'erreur rencontrée ?

    "Ca ne marche pas" n'est pas un bug....

  7. #27
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    j'ai une erreur :

    Mot clé FROM absent à l'emplacement prévu

  8. #28
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Il manque une virgule après MOTIF dans le SELECT.
    ~ Lola ~

  9. #29
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    j'ai ajouté la virgule et j'ai une erreur mot clé absent.

  10. #30
    Membre chevronné
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Points : 1 878
    Points
    1 878
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     WHERE  EXTRACT(MONTH FROM DAT) = 5
    SQLment parlant, c'est pas propre tout ça

  11. #31
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Citation Envoyé par jopont Voir le message
    j'ai ajouté la virgule et j'ai une erreur mot clé absent.
    Pense à remettre la requête, histoire qu'on parte sur de bonnes bases. Et pour voir si tu as corrigé où on pensait.
    ~ Lola ~

  12. #32
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Citation Envoyé par Scriuiw Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     WHERE  EXTRACT(MONTH FROM DAT) = 5
    SQLment parlant, c'est pas propre tout ça
    Pourquoi donc ? C'est bien la bonne syntaxe d'un point de vue norme SQL.


    Moi c'est plutot le case qui me choque.

  13. #33
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Syntaxiquement, et sans tenir compte d'éventuelles subtilités du dialecte SQL Oracle, ceci devrait mieux fonctionner :
    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
    SELECT DAT, MOTIF, 
        SUM(
    		CASE 
    			WHEN SUBSTR( MOTIF, 7, 2) = 'JP' THEN 1 
    			ELSE 0 
    		END
    	) AS JOUR, 
        SUM(
    		CASE 
    			WHEN SUBSTR( MOTIF, 7, 2) = 'NP' THEN 1 
    			ELSE 0 
    		END
    	) AS NUIT 
    FROM  S6PACTI 
    WHERE  EXTRACT(MONTH FROM DAT) = 5
    GROUP BY DAT,MOTIF;
    Maintenant, est-ce que ça donne le bon résultat ?
    À toi de voir.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  14. #34
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    Merci Cinephil,
    Ton code fonctionne.
    Dans ton code, où dois-je placer un ORDER pour classer les résultats par ordre chronologique ?

    Et enfin, comment mettre la condition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE PLPPQUA.CODEQUAL = 'IMP2'
    PLPPQUA est une autre table.

    Je voudrais obtenir dans le résultat:

    DAT/JOUR/NUIT/IMP2 JOUR/ IMP2 NUIT

    Merci

  15. #35
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Citation Envoyé par jopont Voir le message
    Dans ton code, où dois-je placer un ORDER pour classer les résultats par ordre chronologique ?
    ORDER BY se positionne toujours à la fin, éventuellement avant une clause LIMIT (en MySQL ; je ne connais pas l'équivalent en Oracle).

    Et enfin, comment mettre la condition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE PLPPQUA.CODEQUAL = 'IMP2'
    PLPPQUA est une autre table.
    Il faut faire une jointure de cette nouvelle table avec la table de la requête ou avec la requête elle-même. Ça dépend ce que tu veux.

    Je voudrais obtenir dans le résultat:

    DAT/JOUR/NUIT/IMP2 JOUR/ IMP2 NUIT

    Merci
    Tu veux dire que tu veux à la fois les totaux jours et nuit d'une part et les totaux jour et nuit pour IMP2 d'autre part ?
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  16. #36
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    Oui je voudrais les deux.
    Merci

  17. #37
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    Comment faut-il imbriquer la jointure ?
    merci

  18. #38
    Membre éclairé Avatar de Arkhena
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 552
    Points : 769
    Points
    769
    Par défaut
    Bonjour,

    Depuis le début, vous donnez l'impression d'attendre sagement dans votre fauteuil qu'on vienne vous apporter la solution sur un plateau... Je trouve déjà que cinephil en a trop fait, étant donné le peu d'énergie que vous mettez à essayer de comprendre ce qui est fait... La moindre des choses étant de lire les liens fournis...

    Cordialement,

    Arkhena
    A bove ante, ab asino retro, a stulto undique caveto

  19. #39
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    238
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 238
    Points : 0
    Points
    0
    Par défaut
    Bonjour,

    Désolé mais je débute en SQL, alors veuillez m'excuser de ne pas tout comprendre.

    Ce que je ne comprends pas, c'est comment faire intégrer une jointure avec le code de CinePhil.

    Merci

  20. #40
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Je voudrais obtenir dans le résultat:

    DAT/JOUR/NUIT/IMP2 JOUR/ IMP2 NUIT
    Pour le moment, avec la requête, tu as plutôt ces entêtes de colonnes :
    DAT / JOURSPP / NUITSPP / JOURSPV / NUITSPV / ASTJ / ASTN

    Ça ne ressemble pas du tout au résultat que tu souhaites alors il faudrait nous indiquer comment tu pars de l'un pour arriver à l'autre. Ou alors il s'agit d'une demande totalement différente ? Une autre requête à faire ?

    Et si tu as lu l'article sur les jointures dont je t'ai donné le lien, tu verras que pour joindre deux tables (ou une table et une requête, ou deux requêtes), il faut déterminer une condition de jointure qui cherchera généralement à faire correpondre les valeurs d'une colonne d'une table avec les valeurs d'une colonne de l'autre table.

    Nous n'avons pas l'information sur ce qui permettrait de joindre les deux tables, nous ne pouvons donc pas t'aider avec les informations partielles que tu nous donnes.

    Lis la phrase en bleu de ma signature et applique son principe. Et lis aussi les règles applicables à ce forum.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 3 PremièrePremière 123 DernièreDernière

Discussions similaires

  1. [AC-2007] Limite Module VBA Access: 1000 fonctions ou nombre de lignes ?
    Par jacou dans le forum VBA Access
    Réponses: 10
    Dernier message: 13/04/2010, 16h52
  2. Réponses: 4
    Dernier message: 21/12/2009, 11h12
  3. [XL-2007] Range en fonction du nombre de ligne
    Par luko6 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 21/10/2009, 14h26
  4. [SQL2005] requete en fonction du nombre de ligne d'une table
    Par tehes dans le forum Développement
    Réponses: 2
    Dernier message: 21/11/2007, 14h10
  5. [SQL2005] requete en fonction du nombre de ligne d'une table
    Par tehes dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 21/11/2007, 14h10

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