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 :

Sélection sur tables identiques d'après alias


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Femme Profil pro
    Inscrit en
    Avril 2007
    Messages
    209
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2007
    Messages : 209
    Par défaut Sélection sur tables identiques d'après alias
    Bonjour à tous,

    J'ai une petite question que je n'arrive pas à résoudre pour un requête SQL.

    Admettons une table de test avec les données suivantes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    +-------+-------+
    | NO_ID | CHAMP |
    +-------+-------+
    |   1   |   A   |
    +-------+-------+
    |   2   |   B   |
    +-------+-------+
    J'aimerais créer une requête qui me retourne la liste des valeurs possibles pour le champ "CHAMP" sur une seule ligne. (Je suis sur des tables de type Absolute DataBase ou SQL Server, ça dépend mon utilisation, mais le principe est le même)

    J'aimerais donc avoir ce genre de résultat

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    +--------+--------+
    | CHAMP1 | CHAMP2 |
    +--------+--------+
    |   A    |   B    |
    +--------+--------+
    Afin d'éviter de partir sur une requête PIVOT compliquée pour seulement qq champs (Et comme je n'ai pas trouvé le moyen de faire un PIVOT sur de l'absolute database) je voulais partir sur une requête du style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT
    T1.CHAMP AS CHAMP1,
    T2.CHAMP AS CHAMP2
    FROM
    (SELECT CHAMP FROM TABLE WHERE NO_ID = 1) AS T1,
    (SELECT CHAMP FROM TABLE WHERE NO_ID = 2) AS T2
    Qui semble très bien marcher quand les correspondances sont trouvées (NO_ID 1 et NO_ID 2 existent dans la table).

    Le problème est que si je supprime l'enregistrement NO_ID 2 dans la table de départ et que je ré-exécute la requête, tous les résultats sont vides (CHAMP1 et CHAMP2) alors que CHAMP1 devrait avoir une correspondance.

    Savez-vous si il existe une solution pour gérer ce problème?

    Merci d'avance.

    Noémie

  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 : 44
    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,

    La difficulté s'élève car ce que vous recherchez n'est pas "naturel" en SQL : il vous faut ce qu'on pourrait appeler (au risque de me faire enguirlander) un produit cartésien dénormalisé.
    On s'en sort en trichant comme suit :

    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
    19
    20
    21
    22
    23
    24
    25
    DECLARE @t TABLE
    (
    	NO_ID tinyint NOT NULL
    	, colonne char(1) NOT NULL
    )
     
    INSERT INTO @t VALUES (1, 'A')--, (2, 'B')
     
    ;WITH
    	UN AS
    	(
    		SELECT	colonne AS colonne1
    		FROM	@t
    		WHERE	NO_ID = 1
    	)
    	, DEUX AS
    	(
    		SELECT	colonne AS colonne2
    		FROM	@t
    		WHERE	NO_ID = 2
    	)
    SELECT		UN.colonne1
    		, DEUX.colonne2
    FROM		UN
    FULL JOIN	DEUX ON 1 = 1
    @++

  3. #3
    Membre éclairé
    Femme Profil pro
    Inscrit en
    Avril 2007
    Messages
    209
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2007
    Messages : 209
    Par défaut
    Bonjour Elsuket,

    Woooo ça c'est la classe. Effectivement, le "produit cartésien dénormalisé" pique un peu les yeux à la 1ère lecture mais ça fonctionne bien... du moins en SQL Server. j'ai réussi à exécuter ma requête sans problème.
    Malheureusement, la fonction "WITH" ne semble pas être supportée en Absolute Database (Ou du moins pas tel quel). Je continue mes recherches pour cette partie.

    Mais merci beaucoup pour ta réponse.

    Salutations

    Noémie

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 622
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 622
    Billets dans le blog
    10
    Par défaut
    Citation Envoyé par Nono23 Voir le message
    Woooo ça c'est la classe. Effectivement, le "produit cartésien dénormalisé" pique un peu les yeux à la 1ère lecture mais ça fonctionne bien... du moins en SQL Server. j'ai réussi à exécuter ma requête sans problème.
    Malheureusement, la fonction "WITH" ne semble pas être supportée en Absolute Database (Ou du moins pas tel quel). Je continue mes recherches pour cette partie.
    Si vous ne pouvez pas utiliser les CTE, faites simplement des requetes imbriquées select ... from (select ... from...)

  5. #5
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour,

    Il y a sans doute plus simple, à moins que je n'ai loupé une subtilité :

    Avec le jeu d'essai d'ElSuket :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT 
    	MAX(CASE WHEN NO_ID = 1 THEN colonne END) AS Col1
    	,MAX(CASE WHEN NO_ID = 2 THEN colonne END) AS Col2	
    FROM @t

  6. #6
    Membre éclairé
    Femme Profil pro
    Inscrit en
    Avril 2007
    Messages
    209
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2007
    Messages : 209
    Par défaut
    Merci aieeeuuuuu, c'est exactement ça que je cherchais.

    ça marche superbement bien.

    Merci beaucoup

    Nono

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

Discussions similaires

  1. LEFT JOIN sur tables identiques ?
    Par Cyborg dans le forum Langage SQL
    Réponses: 16
    Dernier message: 08/11/2011, 12h18
  2. Sélection sur table complexe
    Par VanVan76 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 16/11/2010, 03h46
  3. requete sur 3 tables identiques
    Par db48752b dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 26/03/2008, 21h31
  4. [SQL] UNION et alias sur table
    Par phoeniix07 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 26/01/2007, 14h19
  5. Sélection sur plusieurs tables
    Par WriteLN dans le forum Requêtes
    Réponses: 19
    Dernier message: 05/10/2005, 15h29

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