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

MS SQL Server Discussion :

[SQL2K] Select de select


Sujet :

MS SQL Server

  1. #1
    Membre habitué
    Inscrit en
    Mai 2006
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 9
    Par défaut [SQL2K] Select de select
    Bonjour,

    Quand je fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    select c1, c2 from (
       select champ1 as c1, champ2 as c2 from matable where [...])
    SQL Serveur est pas content.

    Il semble qu'il faut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    select champ1 as c1, champ2 as c2 into #tmp
    from matable
    where [...]
     
    select c1, c2 from #tmp
     
    drop table #tmp
    ce que je trouve pas très beau...

    Sous Oracle, la première écriture passe. Quel est l'erreur que je fais pour que cela ne passe pas sous SQL Server ?

    Merci

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Août 2005
    Messages
    115
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 115
    Par défaut
    il te dit quoi comme erreur ?

  3. #3
    Membre chevronné
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Mai 2007
    Messages : 356
    Par défaut
    On peut effectuer une requête de type SELECT ... FROM (SELECT ...).

    Le soucis est qu'il faut faire un alias sur le retour du SELECT imbriqué.

    Dans ton cas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT T1.c1, T1.c2 FROM (
       SELECT champ1 AS c1, champ2 AS c2 FROM matable WHERE [...]) AS T1
    Normalement cela fonctionne, j'ai fait un petit test.

    Pourrais-tu me dire si ça répond à ton interrogation ?

  4. #4
    Membre habitué
    Inscrit en
    Mai 2006
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 9
    Par défaut
    Merci Madinico

    ça marche nickel comme ça !!!

    Pour info, le message d'erreur était
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Msg 102, Niveau 15, État 1, Ligne 2
    Syntaxe incorrecte vers ')'.

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Août 2005
    Messages
    115
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 115
    Par défaut
    Bon bah merci ;-)

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

Discussions similaires

  1. select in (select in (select in etc.))
    Par Christophe P. dans le forum Langage SQL
    Réponses: 4
    Dernier message: 28/01/2015, 11h34
  2. Réponses: 6
    Dernier message: 20/11/2007, 11h14
  3. select * ou select count(*) ou select count(id)
    Par wjc dans le forum Requêtes
    Réponses: 12
    Dernier message: 19/12/2005, 19h00
  4. Forms 9i : CURSOR "SELECT 1, (SELECT..&q
    Par McM dans le forum Oracle
    Réponses: 9
    Dernier message: 05/11/2005, 14h02
  5. flexgrid:selection cellule=selection ligne
    Par Terminator dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 20/10/2005, 21h27

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