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 :

Utiliser les variables avec les cursors


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Juillet 2007
    Messages
    44
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 44
    Par défaut Utiliser les variables avec les cursors
    Bonjour,

    J'aurais une question sur l'utilisation des cursors avec des variable.

    Je dois donner les nom de la table dans la déclaration du cursor avec une variable.
    exemple :
    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
    declare @sTable varchar(30)
    set @sTable= 'delete_pgdev10'
     
    declare dbName_cursor cursor for Select dbName from @sTable
     
    OPEN dbName_cursor
    FETCH NEXT FROM dbName_cursor INTO @dbName
     
     
    WHILE @@FETCH_STATUS = 0
    BEGIN
    	set @sqlReq='use ' +@dbname
    	EXEC @sqlReq
          --do something 
     
    END
    FETCH NEXT FROM dbName_cursor
    INTO @dbName
     
    CLOSE dName_cursor
    DEALLOCATE dName_cursor


    Avez vous une idée pour comment utiliser le @sTable?

    Merci beaucoup,
    dnboa

  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
    22 002
    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 : 22 002
    Billets dans le blog
    6
    Par défaut
    Vous pouvez utiliser du SQL dynamique pour la création de la requête générant le dataset du curseur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    DECLARE @sql nvarchar(4000) = 'DECLARE MON_CURSEUR CURSOR FOR SELECT * FROM MA_TABLE'
     
    EXEC sp_executesql @sql;
     
    OPEN MON_CURSEUR;
    FETCH NEXT FROM MON_CURSEUR;
    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/ * * * * *

Discussions similaires

  1. Utiliser une variable avec cette commande awk
    Par gavino dans le forum Shell et commandes GNU
    Réponses: 5
    Dernier message: 30/03/2015, 11h17
  2. Réponses: 2
    Dernier message: 20/01/2014, 12h19
  3. Utilisation de variable avec SSIS
    Par sdionne dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 05/08/2010, 14h01
  4. Utiliser des variables avec Python et Gladfly ?!
    Par Exodus dans le forum Général Python
    Réponses: 5
    Dernier message: 17/09/2007, 09h49
  5. [VBA]comment utiliser des Variables avec Underscore ( _ )
    Par Oceliane dans le forum VBA Access
    Réponses: 4
    Dernier message: 12/04/2007, 17h02

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