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 :

SQL2000 - Déclaration Variable Locale


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    98
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 98
    Par défaut SQL2000 - Déclaration Variable Locale
    Bonjour,

    je rencontre un problème de déclaration de variable et pourtant, je ne vois pas ce qu'il manque, j'ai toujours le même message d'erreur :
    --> La variable '@ValeurChamp' doit être déclarée.

    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
     
    DECLARE @CptColonnes int
    DECLARE @NbColonnes int
    SET @NbColonnes = 256 --nombre initial de colonnes
    DECLARE @SelectColonnes Varchar(5000)
    DECLARE @ValeurChamp Varchar(100)
    DECLARE @NomChamp Varchar(100)
    SET @CptColonnes = 1
     
     
    WHILE @CptColonnes <= @NbColonnes
    BEGIN
    	SET @NomChamp =  'champ'+CAST(@CptColonnes AS VARCHAR(3))
    	SET @SelectColonnes = 'SELECT  @ValeurChamp = '+ @NomChamp+'  FROM MaTable'
    	EXEC(@SelectColonnes)
     
    	SET @CptColonnes = @CptColonnes +1 
    END
    ça fait un petit moment que je tourne en rond, un petit éclaricissement ne serait pas de refus :-)

    Merci d'avance.
    Cordialement,

    Jo

  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 998
    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 998
    Billets dans le blog
    6
    Par défaut
    Une requête dynamique s'exécute hors du contexte de l'appelant. Il n'y a pas moyen que la variable statique et celle générées dynamiquement se voient.

    Vous devriez écrire :
    SET @SelectColonnes = 'SELECT ' + @ValeurChamp + ' = '+ @NomChamp+' FROM MaTable'
    Ceci est d'ailleurs incorrecte (vieille syntaxe anti normative de SQL Server) et devrait être écrit :
    SET @SelectColonnes = 'SELECT ' + @NomChamp + ' AS ' + @ValeurChamp + ' FROM MaTable'
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    98
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 98
    Par défaut
    Merci pour cette réponse rapide.

    effectivement, je n'ai plus de message d'erreur, mais pour autant, je n'arrive pas obtenir de valeur dans la variable @ValeurChamp. Le Code s'exécute sans erreur, mais le print n'affiche rien !

    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
     
    DECLARE @CptColonnes int
    DECLARE @NbColonnes int
    SET @NbColonnes = 256 --nombre initial de colonnes
    DECLARE @SelectColonnes Varchar(5000)
    DECLARE @ValeurChamp Varchar(100)
    DECLARE @NomChamp Varchar(100)
    SET @CptColonnes = 1
     
    WHILE @CptColonnes <= @NbColonnes
     
    BEGIN
    	SET @NomChamp =  'champ'+CAST(@CptColonnes AS VARCHAR(3))
     
    	SET @SelectColonnes = 'SELECT ' + @NomChamp+ ' AS ' + @ValeurChamp + ' FROM Sphynx_TeleVote'
    	EXEC(@SelectColonnes)
    	PRINT @ValeurChamp
    	SET @CptColonnes = @CptColonnes +1 
    END

  4. #4
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    98
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 98
    Par défaut
    j'ai trouvé une solution (grâce à votre piste) qui me permet de mettre en place ce que je souhaitais en passant par une table intermédiaire. Qu'en pensez vous ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SET @SelectColonnes = 'SELECT TOP 1' + @NomChamp + ' AS MonChamp INTO TableTempo FROM Sphynx_TeleVote'
    EXEC(@SelectColonnes)
    SET @ValeurChamp = (SELECT MonChamp FROM TableTempo)
    Merci encore.
    Jo

Discussions similaires

  1. Réponses: 3
    Dernier message: 21/08/2013, 17h54
  2. Déclaration des variables locales
    Par Ecrinel dans le forum Général Java
    Réponses: 5
    Dernier message: 12/06/2012, 15h18
  3. Utiliser la valeur d'un spinner lors de la déclaration d'une variable locale
    Par Jiggazzzzz dans le forum Composants graphiques
    Réponses: 4
    Dernier message: 05/12/2011, 09h31
  4. Function - déclaration variable locales
    Par jollt dans le forum PL/SQL
    Réponses: 4
    Dernier message: 09/09/2008, 16h54
  5. Déclaration et utilisation de variables locales en pile
    Par johan_b dans le forum x86 32-bits / 64-bits
    Réponses: 2
    Dernier message: 04/02/2008, 09h36

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