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

Développement SQL Server Discussion :

Soucis sur une requete imbriquée


Sujet :

Développement SQL Server

  1. #1
    Membre averti Avatar de Gregory.M
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    684
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2007
    Messages : 684
    Points : 309
    Points
    309
    Par défaut Soucis sur une requete imbriquée
    bonjour,

    voici la requete que je fais et qui ne fonctionne pas pour une raison logique: ma requete imbriqué retourne plusieurs résultats.

    Comment fait on lorsque l'on est confronté à ce cas la? une seconde requete? ...

    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
    SELECT BCTL.BusinessCaseID,BCTL.Title
    
    FROM Portal_BusinessCasesToLanguages BCTL,
    Portal_FamilyOfProductsContent FOPC,
    Portal_FamilyOfProductsToLanguages FOPCTL
    
    WHERE 
    FOPC.ContentId = BCTL.BusinessCaseID
    AND
    FOPC.FamilyOfProductId = FOPCTL.FamilyOfProductsId
    AND FOPC.FamilyOfProductId = (select ContentId from Portal_FamilyOfProductsContent
    	where StructureContentTypeId = 4
    	and FamilyOfProductId = 
    		(select FamilyOfProductsId from Portal_FamilyOfProductsToLanguages
    		where LangId=@LanguageID
    		and Title like '%'+@FamilyOfProductText+'%'
    		));

    Merci de vos conseils

  2. #2
    Membre actif
    Inscrit en
    Février 2009
    Messages
    224
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 224
    Points : 269
    Points
    269
    Par défaut
    Bonsjour,
    si votre sous requête retourne plusieurs valeurs vopus ne pouvez pas utiliser l'opérateur =
    POur tester l'appartenence de FamilyOfProductId à la liste de valeur retourné par la sous rqt utilisez l'opérateur IN soit:
    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
    SELECT BCTL.BusinessCaseID,BCTL.Title
    
    FROM Portal_BusinessCasesToLanguages BCTL,
    Portal_FamilyOfProductsContent FOPC,
    Portal_FamilyOfProductsToLanguages FOPCTL
    
    WHERE 
    FOPC.ContentId = BCTL.BusinessCaseID
    AND
    FOPC.FamilyOfProductId = FOPCTL.FamilyOfProductsId
    AND FOPC.FamilyOfProductId = (select ContentId from Portal_FamilyOfProductsContent
    	where StructureContentTypeId = 4
    	and FamilyOfProductId IN 
    		(select FamilyOfProductsId from Portal_FamilyOfProductsToLanguages
    		where LangId=@LanguageID
    		and Title like '%'+@FamilyOfProductText+'%'
    		));

  3. #3
    Membre averti Avatar de Gregory.M
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    684
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2007
    Messages : 684
    Points : 309
    Points
    309
    Par défaut
    super merci!

  4. #4
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Vous pouvez écrire votre requête avec l'expression suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT BCTL.BusinessCaseID,
    		BCTL.Title
    FROM dbo.Portal_BusinessCasesToLanguages BCTL
    JOIN dbo.Portal_FamilyOfProductsContent FOPC ON BCTL.ContentId = BCTL.BusinessCaseID
    JOIN dbo.Portal_FamilyOfProductsToLanguages FOPCTL ON FOPC.FamilyOfProductId = FOPCTL.FamilyOfProductsId
    WHERE FOPCTL.LangId = @LanguageID
    AND FOPCTL.Title LIKE '%' + @FamilyOfProductText + '%'
    AND FOPC.StructureContentTypeId = 4
    C'est la même chose en plus performant et en plus lisible

    @++

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

Discussions similaires

  1. Soucis sur une requete UPDATE imbriquée
    Par fidelcastor77 dans le forum Développement
    Réponses: 3
    Dernier message: 30/03/2009, 17h10
  2. Condition sur une requete imbrique
    Par VolaiL dans le forum Langage SQL
    Réponses: 6
    Dernier message: 06/11/2008, 13h09
  3. [MySQL] souci sur une requete avec jointure
    Par fey dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 08/09/2008, 11h11
  4. Réponses: 2
    Dernier message: 11/01/2006, 15h49
  5. []débogage sur une requête dasn visual basic
    Par mcay dans le forum VB 6 et antérieur
    Réponses: 19
    Dernier message: 24/09/2003, 09h59

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