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 :

Parametre pour un DTS


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite
    Avatar de HULK
    Inscrit en
    Juillet 2003
    Messages
    1 276
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 276
    Par défaut Parametre pour un DTS
    Bonjour, pour executer un DTS dans une procedure stockée j'utilise ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    EXEC master..xp_cmdshell 'DTSRun /STOTO /E /NTRANSFERT_HISTORY
    TOTO etant le nom de mon serveur et TRANSFERT_HISTORY étant le nom de mon DTS.

    Je voudrais lui passer un parametre appelé period, apparemment c'est ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    EXEC master..xp_cmdshell 'DTSRun /STOTO /E /NTRANSFERT_HISTORY /Aperiod:typeid=int
    déjà si qqun pouvait me confirmer ca.

    Ensuite je voudrais que ma variable soit dynamique, ce n'est plus period mais @period, alors là comment faire ??
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    EXEC master..xp_cmdshell 'DTSRun /STOTO /E /NTRANSFERT_HISTORY /A@period:typeid=int
    ou alors
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    EXEC master..xp_cmdshell 'DTSRun /STOTO /E /NTRANSFERT_HISTORY /A'+ @period + ':typeid=int
    ????

    Merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 228
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 228
    Billets dans le blog
    25
    Par défaut
    L'appel se fait via l'OS (d'où le xp_cmdshell) et pas T-SQL, donc je doute qu'un @... soit bien interprété.

    Pourquoi ne pas traiter en T-SQL au travers du package?
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  3. #3
    Membre émérite
    Avatar de HULK
    Inscrit en
    Juillet 2003
    Messages
    1 276
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 276
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Pourquoi ne pas traiter en T-SQL au travers du package?
    Comprends pas ...

  4. #4
    Membre Expert
    Avatar de rudib
    Homme Profil pro
    Fakir SQL Server & NoSQL
    Inscrit en
    Mai 2006
    Messages
    2 573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Fakir SQL Server & NoSQL

    Informations forums :
    Inscription : Mai 2006
    Messages : 2 573
    Par défaut
    Bonjour,

    Pour ajouter le paramètre, c'est la deuxième solution : tu dois le concaténer avec ta chaîne d'appel, tu ne peux pas l'interpoler.
    Ceci dit, tu dois le faire dans une variable avant xp_cmdshell. Je ne pense pas qu'il accepte la chaîne en paramètre (à vérifier).

    Pour générer ton appel de DTS, le plus simple est d'utiliser dtsrunui.exe, qui te permet de le faire visuellement, et ensuite de générer la commande.

  5. #5
    Membre habitué
    Inscrit en
    Février 2004
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Février 2004
    Messages : 11
    Par défaut
    ce ne serai pas plutot cela?

    EXEC master..xp_cmdshell 'DTSRun /STOTO /E /NTRANSFERT_HISTORY /Aperiod:int='+ @period + '

  6. #6
    Membre habitué
    Inscrit en
    Février 2004
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Février 2004
    Messages : 11
    Par défaut
    J'ai fait un essai avec une de mes table

    voici la requête sql:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    use wms
     
    declare @client varchar (8)
    declare @parm   varchar(120)
     
    set @client = '05420   '
     
    set @parm = 'DTSRun /Sserveur /E /Ntest_H5 /Aclient:8="'+ @client + '"'
    print @parm
     
    EXEC master..xp_cmdshell @parm

    :8 indique une chaine de caracteres

    la variable client doit etre definie dans le lot DTS

    la requete dans le lot:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from H5 where hfh012 ( n° client) = ?
    J'espere que cela vous aidera.

Discussions similaires

  1. xsl:for-each avec un parametre pour select
    Par arnog dans le forum XSL/XSLT/XPATH
    Réponses: 7
    Dernier message: 26/08/2008, 13h09
  2. Parametre pour DTS
    Par MetaGolgot dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 18/12/2007, 22h20
  3. Paramètre pour spécifier répertoire décompression avec tar
    Par snoop dans le forum Shell et commandes GNU
    Réponses: 7
    Dernier message: 05/06/2006, 11h00
  4. Réponses: 2
    Dernier message: 14/03/2005, 19h55
  5. [novice]parametre pour dll
    Par tixu dans le forum C++
    Réponses: 4
    Dernier message: 12/11/2004, 14h32

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