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 :

Petit problème sur une requete sql


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 43
    Points : 27
    Points
    27
    Par défaut Petit problème sur une requete sql
    Bonjour à tous !

    J'ai un petit problème de requete je n'arrive pas à reccuperer ce que je veux.

    Je vous explique la situation :

    J'ai un magasin de vente de produit sur internet. J'ai des catégories de produit, tel que la catégorie de produit pour les Femmes, les Hommes, Micro-Informatique...

    Dans chaque catégorie, j'ai des types de produit. Par exemple dans la categorie Femme je peux avoir les types : Veste, Jeans, Chaussure, Ceinture...

    Et enfin pour Chaque Type de produits j'ai des produits.
    Par exemple pour la categorie femme, et le type Jeans j'ai le produit Levis.

    Ma base est composée d'une table categorie (Id categorie, nom categorie)
    d'une table type (id type , nom type, et la clé etrangere id categorie, )
    et la table produit (id produit, nom produit, et la clé etrangere id produit)

    Mon problème est le suivant :

    Je souhaite récupérer les types de la catégorie femme, ou dans chaques type de cette categorie, il y a au moins 1 produit.

    C'est à dire que si j'ai un type jeans de la categorie femme et que il n'y a pas de produit dedans je ne veut pas reccuperer le type !

    Voila ce que j'ai ma requete, mais il n'apprécie pas du tt le COUNT...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT t.NOM_TYPE FROM CATEGORIE c, TYPE t, PRODUIT p 
    WHERE (p.ID_TYPE = t.ID_TYPE AND t.ID_CATEGORIE = c.ID_CATEGORIE 
    AND c.NOM_CATEGORIE = 'Femme' AND COUNT(p.ID_PRODUIT)>0)
    Désolé pour ce roman... en espérant que vous trouviez une solution,

    Merci à tous et bonne journée

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    280
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 280
    Points : 344
    Points
    344
    Par défaut
    Salut,

    Il y a plusieurs maniere de le faire.
    Certaines plus elegante et/ou rapide que d'autres.

    En voici une qui est ce qu'elle est. A voir si elle n'est pas pas trop lente chez toi:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT DISTINCT t.NOM_TYPE 
    FROM CATEGORIE c
    JOIN TYPE t ON c.ID_CATEGORIE=t.ID_CATEGORIE
    JOIN PRODUIT p ON t.ID_TYPE=p.ID_TYPE 
    WHERE c.NOM_CATEGORIE = 'Femme'
    ---
    Farid

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 43
    Points : 27
    Points
    27
    Par défaut
    Ahhhhhhh trop bien ça marche super !!!

    Je te remercie beaucoup ! Jvais enfin pouvoir dormir cette nuit

    Bonne journée

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 43
    Points : 27
    Points
    27
    Par défaut
    Juste une petite question au passage, que change l'utilisation du JOIN ON, par rapport à la jointure manuelle que j'ai faite (p.id_type = t.id_type)?

    Merci

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    280
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 280
    Points : 344
    Points
    344
    Par défaut
    Plus facile a lire

    Mais il me semble que tu gagnes aussi en performance, suivant la facon dont tes tables sont construitent.

    Mais si tu prends ta requete originel, et retire le "AND COUNT(p.ID_PRODUIT)>0)" tu devrais avoir le meme resultat.

    ---
    Farid.

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 43
    Points : 27
    Points
    27
    Par défaut
    Oki oki,

    Merci encore pour les infos

    Bonne journée Farid

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

Discussions similaires

  1. petit problème sur une requete
    Par mrdesign38 dans le forum Requêtes
    Réponses: 3
    Dernier message: 02/11/2012, 13h06
  2. [SQL Server] Une petite aide sur une requete
    Par irenee dans le forum Langage SQL
    Réponses: 9
    Dernier message: 24/04/2006, 16h08
  3. [MySQL 4.1] probleme d'accents sur une requete SQL
    Par tatayoyo dans le forum Langage SQL
    Réponses: 4
    Dernier message: 10/11/2005, 16h06
  4. pb ordre sur une requete SQL
    Par richard038 dans le forum Bases de données
    Réponses: 2
    Dernier message: 03/08/2005, 15h26
  5. petite aide sur une requete INSERT INTO
    Par bonneti dans le forum Langage SQL
    Réponses: 3
    Dernier message: 14/03/2005, 15h17

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