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 :

Arreter un lot DTS proprement


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 1
    Par défaut Arreter un lot DTS proprement
    bonjour,

    j'ai cree une dts pour charger un fichier .txt dans mes bases de données et traiter ensuite ses données (au fichier).

    voila et donc je fais un test pour savoir si le fichier existe et n'est pas vide.
    si mon fichier est bon je fais mes traitements, sinon je veux arreter mon lot dts mais sans sortir avec un code "echec".

    mais je ne trouve de commande pour ca en vbscript, une commande qui permette de sortir du lot sans probleme ou message type "task report a failure ..."

    voici le code:

    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
    Set fso = CreateObject("Scripting.FileSystemObject")
          IF (fso.FileExists(PathFichier)) THEN
    	Msgbox "fichier existe"
    	set fil1 = fso.GetFile(PathFichier)
    	IF fil1.size > 0  THEN 
    	MSGBOX "fichier non vide"
    		Main = DTSTaskExecResult_Success ou DTSStepScriptResult_ExecuteTask
    	ELSE 
    	MSGBOX "fichier vide"	
    	Main = DTSTaskExecResult_Failure ou DTSStepScriptResult_DontExecuteTask
    	END IF
          ELSE 
    	Msgbox "fichier existe pas "
     	Main = DTSTaskExecResult_Failure ou DTSStepScriptResult_DontExecuteTask 
         END IF

    je voudrais donc eviter d'utiliser les constantes DTSTaskExecResult_Failure ou DTSStepScriptResult_DontExecuteTask,
    y a t il un moyen de lui dire stop, arrete toi là (à la dts) ou va executer la tache XXXX ????

    merci de vos reponses

    BenK

  2. #2
    Membre du Club
    Homme Profil pro
    Architecte
    Inscrit en
    Juin 2005
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Architecte
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juin 2005
    Messages : 8
    Par défaut
    Pour continuer sur une tache plutot qu'une autre, tu peux essayer ceci :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SET pkg = DTSGlobalVariables.Parent
    SET stpContinuePkg = pkg.Steps("DTSStep_DTSActiveScriptTask_3")
    SET stpExitBadDirectory = pkg.Steps("DTSStep_DTSActiveScriptTask_2")
    stpContinuePkg.DisableStep = True
    stpExitBadDirectory.DisableStep = False
    Dans ce cas précis, mon script va permettre l'arrêt de ma tâche courante N°3 et
    rediriger mon DTS vers ma tâche N°2 dans laquelle j'affiche un message d'erreur .

    Un site de référence : sqldts.com


Discussions similaires

  1. Lancer un lot DTS dans une prodédure stockée
    Par Guizz dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 24/04/2007, 10h03
  2. [DTS] exécuter un lot DTS depuis T-SQL (sp_OAMethod)
    Par Yann dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 04/11/2004, 11h24
  3. lots DTS et variables
    Par le_scrameustache dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 30/09/2004, 17h54
  4. [MaxDB] travaux et lots DTS
    Par nic_moq dans le forum Autres SGBD
    Réponses: 2
    Dernier message: 19/03/2004, 09h47
  5. travaux et lots DTS
    Par nic_moq dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 17/03/2004, 18h00

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