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 :

Exécuter une procédure stockée dans plusieurs bases automatiquement d'un même serveur


Sujet :

Développement SQL Server

  1. #1
    Nouveau membre du Club
    Inscrit en
    Octobre 2008
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 38
    Points : 30
    Points
    30
    Par défaut Exécuter une procédure stockée dans plusieurs bases automatiquement d'un même serveur
    Bonjour !

    J'ai créer une procédure stockées qui met à jour une table dans une base de données, alors j'ai aussi la même table dans d'autres base de données de mon serveur; je voudrais savoir comment exécuter la procédure stockée automatiquement dans toutes les bases de données de mon serveur.




    Merci

  2. #2
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 154
    Points : 7 403
    Points
    7 403
    Billets dans le blog
    1
    Par défaut
    Que fait la SP ?

    Tu peux exécuter du SQL dynamique en utilisant la commande "EXECUTE"
    https://docs.microsoft.com/fr-fr/sql...ql-server-2017

    Tu peux donc par exemple faire :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select concat('insert into ', name, '.dbo.matable (id, name) values (1, ''TOTO'');') from sys.databases d

    Et faire un curseur dessus qui fait un EXECUTE de chaque ligne retournée.
    On ne jouit bien que de ce qu’on partage.

  3. #3
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 770
    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 770
    Points : 52 726
    Points
    52 726
    Billets dans le blog
    5
    Par défaut
    Ou encore créer une procédures stockée systèmes pour pouvoir l'exécuter dans toutes les bases.

    À me lire : https://blog.developpez.com/sqlpro/p...able_de_toutes

    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/ * * * * *

  4. #4
    Nouveau membre du Club
    Inscrit en
    Octobre 2008
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 38
    Points : 30
    Points
    30
    Par défaut
    En réalité j'ai ma procédure updateEtudiantV6 qui marche lorsque je suis dans la base Etudiant, j'ai également 3 autres bases dans la même instance.
    je voudrais faire du genre que lorsque j’exécute la procédure stockée updateEtudiantV6 dans la base étudiant, que les autres bases puissent être impacter au même moment sans que j'ai à refaire la même chose dans chaque base.

    exécuter cette procédure: exec updateEtudiantV6 Etu120;



    Merci

  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 770
    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 770
    Points : 52 726
    Points
    52 726
    Billets dans le blog
    5
    Par défaut
    Alors créez la dans msdb et utilisez une requête dynamique qui est lancée sur les 3 bases avec en debut de script un USE mabase;

    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. [SQL-Server] Exécuter une procédure stockée dans une boucle
    Par jacko842 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 22/01/2015, 12h27
  2. [WD19] Exécuter une requête stockée dans procédure stockée
    Par clocktime dans le forum WinDev
    Réponses: 0
    Dernier message: 09/04/2014, 08h51
  3. appeler une procédure stockée dans une base mysql
    Par mennou dans le forum Hibernate
    Réponses: 4
    Dernier message: 16/06/2008, 01h58
  4. Réponses: 2
    Dernier message: 20/03/2007, 17h00
  5. Exécution d'une procédure stockée dans Sql
    Par Pascalp dans le forum Access
    Réponses: 4
    Dernier message: 01/09/2006, 11h47

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