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 :

Curseur avec select en paramétre


Sujet :

MS SQL Server

  1. #1
    Membre habitué
    Inscrit en
    Septembre 2002
    Messages
    233
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 233
    Points : 131
    Points
    131
    Par défaut Curseur avec select en paramétre
    Bonjour,

    Je ne parviens pas a compiler une procédure stocké contenant un curseur associé a une requete select dans une variable :

    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 @sQuery VARCHAR(600)
    DECLARE @id INTEGER
     
    SELECT @sQuery = 'SELECT id FROM tab'
     
    DECLARE curseur CURSOR FOR @sQuery
    OPEN curseur
     
    	FETCH NEXT FROM curseur_eng INTO @id
     	WHILE @@FETCH_STATUS = 0
    	BEGIN
     
     
     
    		FETCH NEXT FROM curseur INTO @id
    	END
    CLOSE curseur
    DEALLOCATE curseur_eng
    Voici l'erreur, est ce possible de faire ca ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Msg 170, Level 15, State 1, Line 7
    Line 7: Incorrect syntax near '@sQuery'.
    Merci

  2. #2
    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
    pourquoi tu fais pas ?

    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
     
     
    DECLARE curseur_eng CURSOR FOR 
    SELECT id FROM tab
     
    DECLARE @id INTEGER
     
    OPEN curseur_eng
     
    	FETCH NEXT FROM curseur_eng INTO @id
     	WHILE @@FETCH_STATUS = 0
    	BEGIN
     
    		FETCH NEXT FROM curseur_eng INTO @id
    	END
    CLOSE curseur_eng
    DEALLOCATE curseur_eng

  3. #3
    Membre habitué
    Inscrit en
    Septembre 2002
    Messages
    233
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 233
    Points : 131
    Points
    131
    Par défaut
    Merci pour la réponse, mon exemple que j'ai mis est mal choisi car @sQuery represente en fait dans mon cas une requete créée dynamiquement.

    donc la solution est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SET @sQuery = 'DECLARE curseur CURSOR FOR '
    SET @sQuery = @sQuery + ' SELECT ....'
    SET @sQuery = @sQuery + '  FROM ...' + @aaaaa
    EXEC (@sQuery);
     
    OPEN curseur
    ...

Discussions similaires

  1. Réponses: 7
    Dernier message: 07/04/2011, 21h27
  2. [XSLT] Apply-templates avec select paramétré par un attribut
    Par datrinite dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 26/02/2010, 11h34
  3. [SqlServer 2K] curseurs avec SELECT contenant des variables
    Par yinyang dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 27/07/2006, 10h25
  4. Ouvrir un curseur avec une requête paramétrée?
    Par nnj dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 11/07/2005, 14h12
  5. [PL/SQL] Curseur avec Paramètre
    Par blids dans le forum Oracle
    Réponses: 5
    Dernier message: 10/10/2004, 20h07

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