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 :

Réutilisation d'un champs d'une requête


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    32
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 32
    Par défaut Réutilisation d'un champs d'une requête
    Bonjour,

    Je souhaite dans une même requête réutiliser un champ issue de la requête. Par exemple dans une colonne je fais une fonction complexe et je souhaite réutiliser ce résultat dans la même requête. C'est faisable sous access mais je n'arrive pas à trouver comment faire sous SQL Server 2005.
    Sur access la syntaxe serait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT test.c1*100 AS Expr1, [Expr1]/test.c2 AS Expr2 FROM test;
    J'ai volontairement simplifié la fonction
    Quelque à une idée s'il y a quelque chose de simple, ou faut-il que je passe par une fonction?

    D'avance merci.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT test.c1*100 AS Expr1, test.c1*100/test.c2 AS Expr2 FROM test;

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    32
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 32
    Par défaut
    Certes, mais la fonction est plutôt dans ce style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CONVERT(DECIMAL,SUBSTRING(test.c1,1,PATINDEX('%p%',test.c1)-1))
    Et je dois le réutiliser dans 4 champs. Si SQL Server refait 4 fois la même fonction, au lieu de la faire 1 fois et de la réutiliser 4 fois ca peut allonger le temps d'exécution de la requête.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    with MA_table 
    (
       SELECT *, CONVERT(DECIMAL,SUBSTRING(test.c1,1,PATINDEX('%p%',test.c1)-1)) AS Expr1 
       FROM test 
    )
    select Expr1, Expr1/Ma_Table.c2 AS Expr2
    from Ma_Table
    Je ne sais pas ce que ça donne au niveau performance.

    Évidemment, au lieu de *, je conseille fortement que tu mettes au propre les noms des champs...

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    32
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 32
    Par défaut
    Ca marche

    Merci pour l'aide

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 17/10/2005, 17h13
  2. Champs d'une requête et Colonne d'une grille rattaché
    Par Andry dans le forum Bases de données
    Réponses: 4
    Dernier message: 11/10/2005, 09h39
  3. Pb de type de champs dans une requête
    Par djouahra.karim1 dans le forum Bases de données
    Réponses: 5
    Dernier message: 23/05/2005, 15h19
  4. Changement valeur d'un champ dans une requête
    Par Mimile28 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 07/04/2005, 14h28
  5. [SQL] Renommer un champ dans une requête
    Par martonpylon12 dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 15/11/2003, 01h59

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