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 :

Requete SQL DIFF


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Morad ISSOULGHANE
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : Maroc

    Informations forums :
    Inscription : Juin 2009
    Messages : 98
    Par défaut Requete SQL DIFF
    Bonjour,

    J'ai une Vue1 qui retourne (champs1, champs2, champs3, champs4)

    eu une autre Vue2 qui retourne (champs1, champs2, champs3, champs4)

    Je veux avoir dans une vue les enregistrements, tel que le couple (champs1, champs2) de la première vue est différent du couple (champs1, champs2) de la deuxième vue.

    Exemple :

    Vue1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    champs1  | champs2  | champs3  | champs4
       1         |      a       |     rr        | tt
       1         |      b       |     rr        | tt
       1         |      c       |     rr        | tt
       2         |      a       |     rr        | tt
       2         |      b       |     rr        | tt

    Vue2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    champs1  | champs2  | champs3  | champs4
       1         |      a       |     gr        | tt
       1         |      b       |     tt        | tt
       1         |      c       |     gr        | tt
       2         |      a       |     tt        | tt
       2         |      b       |     gr        | tt
       2         |      c       |     tt        | tt
    La vue résultat doit retourner
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    champs1  | champs2  | champs3  | champs4
     2           |      c       |     tt        | tt
    Merci boucoup

  2. #2
    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 : 43
    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
    Par défaut
    Bonjour,

    Sous SQL Server 2005 et 2008, vous pouvez écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    WITH
    	CTE AS
    	(
    			SELECT colonne1, colonne2
    			FROM dbo.maVue2
    		EXCEPT
    			SELECT colonne1, colonne2
    			FROM dbo.maVue1
    	)
    SELECT colonne1, colonne2, colonne3, colonne 4
    FROM dbo.maVue2 AS V
    JOIN CTE AS C
    	ON V.colonne1 = C.colonne1
    	ON V.colonne2 = C.colonne2
    Documentation de EXCEPT.

    @++

  3. #3
    Membre confirmé Avatar de Morad ISSOULGHANE
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : Maroc

    Informations forums :
    Inscription : Juin 2009
    Messages : 98
    Par défaut
    Erreur lors de l'exécution de la requête :
    Syntaxe incorrecte vers le mot clé ON !!

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    123
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 123
    Par défaut
    Bonjour,

    essayez de remplacer le deuxième 'ON' par un 'AND'
    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
     
    WITH
    	CTE AS
    	(
    			SELECT colonne1, colonne2
    			FROM dbo.maVue2
    		EXCEPT
    			SELECT colonne1, colonne2
    			FROM dbo.maVue1
    	)
    SELECT colonne1, colonne2, colonne3, colonne 4
    FROM dbo.maVue2 AS V
    JOIN CTE AS C
    	ON  V.colonne1 = C.colonne1
    	AND V.colonne2 = C.colonne2

  5. #5
    Membre confirmé Avatar de Morad ISSOULGHANE
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : Maroc

    Informations forums :
    Inscription : Juin 2009
    Messages : 98
    Par défaut
    Exacte

    Je l'ai fait hier, mais je ne l'ai pas posté !!! j'était creuvé

    Merci quand même

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

Discussions similaires

  1. Problème Requete SQL et QuickReport
    Par arnaud_verlaine dans le forum C++Builder
    Réponses: 7
    Dernier message: 07/01/2004, 09h31
  2. Prob de requete sql et variable
    Par agent-zaizai dans le forum ASP
    Réponses: 11
    Dernier message: 21/10/2003, 16h54
  3. requete sql
    Par autumn319 dans le forum ASP
    Réponses: 22
    Dernier message: 10/09/2003, 16h46
  4. Paramètre requete SQL (ADOQuery)
    Par GaL dans le forum C++Builder
    Réponses: 3
    Dernier message: 30/07/2002, 11h24
  5. Resultat requete SQL
    Par PierDIDI dans le forum Bases de données
    Réponses: 2
    Dernier message: 23/07/2002, 13h43

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