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 :

Nom de colonne variable


Sujet :

MS SQL Server

  1. #1
    Nouveau membre du Club

    Inscrit en
    Février 2006
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 29
    Points : 27
    Points
    27
    Par défaut Nom de colonne variable
    Bonjour

    Dans une procédure stockée, comment faire pour interpréter une variable de type Varchar comme un nom de colonne???

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    create table #test(id int)
    insert into #test(id) values(0)
    declare @nomColonne varchar(10)
    set @nomColonne = 'id'
    select @nomColonne from #test
    drop table #test
    Ce code retourne la chaine 'id' alors que je voudrais qu'il me retourne 0


    En fait je voudrais comparer 2 entrées d'une table et afficher la liste des colonnes pour lesquelles les valeurs des 2 entrées sont différentes.

    Voici mon code :
    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
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    create proc ps_compareDevis
     @numDevis1 int,
     @numDevis2 int
    as
    begin
    -- La table temporaire pour stocker les colonnes différentes
    create table #tab(nomColonne varchat(50))
    
    -- On parcours toutes les colonnes de la table
    declare curseur cursor for
    select	c.[name] as [nomColonne]
    from	[sysobjects] o inner join 
    	[syscolumns] c on o.[id] = c.[id]
    where  o.[name] = 'Devis'
    open curseur -- On ouvre le curseur
    fetch curseur into @nomColonne -- On lit la 1er colonne
    while @@FETCH_STATUS = 0 begin
         if @nomColonne != 'numDevis' begin
              if (select @nomColonne from Devis where numDevis=@numDevis1) not like (select @nomColonne from Devis where numDevis=@numDevis2)) begin
                   -- Les deux entrée de la table devis ne sont pas identique
                   insert into #tab(nomColonne) values(@nomColonne)
              end
         end -- Fin @nomColonne != 'numDevis'
         -- On passe à la colonne suivante
         fetch curseur into @nomColonne
    end -- Fin while
    
    close curseur
    deallocate curseur
    
    -- On affiche la liste des colonnes
    select * from #tab
    drop table #tab
    
    end --Fin de la procedure
    Merci de votre aide

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 896
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 896
    Points : 53 126
    Points
    53 126
    Billets dans le blog
    6
    Par défaut
    Votre problème étant mal expliqué difficile de le comprend. Auriez un cas concret, un exemple ? Que voulez vous faire ???

    A +

  3. #3
    Membre éprouvé
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Août 2006
    Messages
    730
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 730
    Points : 923
    Points
    923
    Par défaut
    passe par execsql:
    je te mets juste le bloc

    par contre ne connaissant pas le type de tes données il faudra peut-être mettre des quotes avant les @ si varchar, pas utile si int

    ***************************
    declare @cmd varchar(500)

    set @cmd= ' if (select'+ @nomColonne+' from Devis where numDevis='+@numDevis1'+) not like (select '+@nomColonne+' from Devis where numDevis='+@numDevis2+')) begin
    insert into #tab(nomColonne) values('+@nomColonne+')'

    exec @cmd

    ***************************
    salut
    serge

  4. #4
    Nouveau membre du Club

    Inscrit en
    Février 2006
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 29
    Points : 27
    Points
    27
    Par défaut
    Salut serge0934

    Merci pour ta réponse

    J'ai déjà essayé cette solution mais à priori je ne peux executer que des procédures stockées via exec

    Lorsque je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    declare @cmd varchar(255)
    set @cmd = 'SELECT * FROM devis'
    exec @cmd
    J'ai le code d'erreur suivant :
    Msg 2812, Niveau 16, État 62, Ligne 3
    Procédure stockée 'SELECT * FROM devis' introuvable.

    Y a-t-il une option à activer sur le serveur pour pouvoir executer des requêtes via la fonction exec ?

    J'utilise SQL Server 2005 Expresse SP1 avec Reporting Services

    Merci d'avance

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 896
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 896
    Points : 53 126
    Points
    53 126
    Billets dans le blog
    6
    Par défaut
    EXECUTE (@cmd)
    ou
    EXEC (@cmd)

    et non

    exec @cmd

    Parentèses oubliées

    A +

  6. #6
    Nouveau membre du Club

    Inscrit en
    Février 2006
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 29
    Points : 27
    Points
    27
    Par défaut
    Merci merci merci 1000 fois merci

    SQLpro tu portes vraiment bien ton nom

    @+

Discussions similaires

  1. [PDO] nom de colonne variable dans la requête SQL
    Par tete-jaune dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 11/06/2014, 11h19
  2. Nom de colonne variable dans tMap
    Par JPH.mega dans le forum Développement de jobs
    Réponses: 1
    Dernier message: 28/01/2013, 16h44
  3. Procédure stockee avec variable de nom de colonne
    Par nicolasj7777 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 28/11/2008, 15h43
  4. PL/pgSQL : conflit entre variable et nom de colonne
    Par archeboc dans le forum PostgreSQL
    Réponses: 10
    Dernier message: 26/03/2008, 12h10
  5. nom de colonne dans une variable
    Par cyclone_yas dans le forum SQL
    Réponses: 12
    Dernier message: 27/12/2006, 10h41

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