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 :

Insérer des lignes dans une PS ou un déclencheur de façon automatique


Sujet :

Développement SQL Server

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2016
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Octobre 2016
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Insérer des lignes dans une PS ou un déclencheur de façon automatique
    Bonjour,

    J'aimerais pouvoir insérer des lignes de façon automatique (via un script/une fonction/...) en début et/ou en fin d'un déclencheur ou d'une procédure stockée.
    Pour le moment je dois ouvrir chacune de mes PS les unes après les autres pour pouvoir y rajouter les lignes qui m'intéressent.

    Exemple:

    Début de déclencheur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    USE [TEST]
    GO
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER OFF
    GO
     
    ALTER TRIGGER [dbo].[DECLENCHE_RECAP_DEVIS_DETAIL] ON [dbo].[DEVISDETAIL] 
    FOR INSERT, UPDATE, DELETE 
    AS
     
    DECLARE 
    @N_Ligne int

    J'aimerais ici insérer un "SET NOCOUNT ON" entre le "AS" et le "DECLARE"
    Dans la même logique j'aimerais ensuite rajouter un "SET NOCOUNT OFF" en toute fin de déclencheur.



    Existe t-il donc des fonctions/solutions me permettant d'effectuer cela automatiquement ?


    Merci d'avance pour vos réponses.

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Je ne vois pas de façon simple pour faire cela automatiquement, car il faudrait parser un minimum les instructions afin de trouver à coup sûr le début et la fin de chaque procédure ou trigger. Cela serait au final probablement bien plus long que de le faire à la main.

    Cela dit, pour le faire à la main, vous pouvez récupérer tous les scripts d'un coup depuis la table sys.sql_modules.
    Il vous restera ensuite à remplacer les CREATE par des ALTER (attention à ne pas remplacer ceux qui sont à l’intérieur des procédures, par exemple création de table temporaire...) et à ajouter vos lignes NOCOUNT à la main. Enfin, après vérification, lancez le script.

  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 768
    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 768
    Points : 52 577
    Points
    52 577
    Billets dans le blog
    5
    Par défaut
    Vous ne pouvez pas le faire figurer AVANT le AS. Le corps du code commence toujours après.

    Vous pouvez utiliser un template ou en egistrer une dans l'explorateur de modèle (le template CREAT PROCEDURE contient d'ailleurs le SET NOCOUNT ON)

    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 Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2016
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Octobre 2016
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci à vous pour les infos.

    Oui SQLPRO, j'ai bien précisé après le AS justement. "Entre le AS et le DECLARE".

Discussions similaires

  1. [AC-2000] Insérer des lignes dans une liste de choix
    Par Aeltith dans le forum VBA Access
    Réponses: 15
    Dernier message: 02/10/2009, 14h18
  2. Insérer des lignes dans une matrice
    Par you_go dans le forum Fortran
    Réponses: 2
    Dernier message: 21/08/2009, 12h10
  3. Insérer des lignes dans une table efficacement
    Par newbie82 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 31/07/2007, 17h01
  4. [VBA-E] Problème pour insérer des lignes dans une feuille Excel
    Par skystef dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 16/04/2007, 14h13
  5. Insérer des lignes dans une StringGrid
    Par da_latifa dans le forum Composants VCL
    Réponses: 1
    Dernier message: 26/09/2005, 12h45

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