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

Windows Discussion :

Vider une variable pour éviter de boucler dans un batch


Sujet :

Windows

  1. #1
    Membre du Club Avatar de smooncef
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    118
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 118
    Points : 66
    Points
    66
    Par défaut Vider une variable pour éviter de boucler dans un batch
    Bonjour,

    comment supprimer la valeur de ma variable, car lorsque je renseigne N à la première question et N à la deuxième, il suffit que je valide sans taper quoi que ce soit et je boucle tout le temps. Car le N est initialisé dans mes variables et elles ne se vident pas.

    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    
    @ECHO off
    
    :debut
    CLS
    @ECHO Voulez-vous detacher les bases de donnees ? Y or N
    @SET /P REPONSE1=Reponse : 
    @IF '%REPONSE1%' == '' GOTO debut
    @IF %REPONSE1% == y GOTO suite
    @IF %REPONSE1% == Y GOTO suite
    @IF %REPONSE1% == n GOTO quitter
    @IF %REPONSE1% == N GOTO quitter
    
    :quitter
    CLS
    @echo Voulez-vous quitter le programme ? Y or N
    @SET /P REPONSE2=Reponse : 
    @IF '%REPONSE2%' == '' GOTO quitter
    @IF %REPONSE2% == y GOTO fin
    @IF %REPONSE2% == Y GOTO fin
    @IF %REPONSE2% == n GOTO debut
    @IF %REPONSE2% == N GOTO debut
    
    :suite
    @ECHO Lancement du detachement des bases futiles !
    osql -Usa -P -i requete.sql
    PAUSE
    
    :fin

  2. #2
    Débutant  
    Avatar de koKoTis
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 438
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 438
    Points : 2 415
    Points
    2 415
    Par défaut
    pour vider ta variable:
    tu mes rien aprés le =

  3. #3
    Membre du Club Avatar de smooncef
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    118
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 118
    Points : 66
    Points
    66
    Par défaut
    Citation Envoyé par koKoTis Voir le message
    pour vider ta variable:
    tu mes rien aprés le =
    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
    22
    23
    24
    25
    26
    27
    28
    @ECHO off
    
    @SET REPONSE1=
    @SET REPONSE2=
    
    :debut
    CLS
    @ECHO Voulez-vous detacher les bases de donnees ? Y or N
    @SET /P REPONSE1=Reponse : 
    @IF '%REPONSE1%' == '' GOTO debut
    @IF /I %REPONSE1% == y GOTO suite
    @IF /I %REPONSE1% == n GOTO quitter
    
    :quitter
    CLS
    @echo Voulez-vous quitter le programme ? Y or N
    @SET /P REPONSE2=Reponse : 
    @IF '%REPONSE2%' == '' GOTO quitter
    @IF /I %REPONSE2% == y GOTO eof
    @IF /I %REPONSE2% == n GOTO debut
    
    :suite
    @ECHO Lancement du detachement des bases futiles !
    osql -Usa -P -i requete.sql
    PAUSE
    
    :eof
    C'est fait, mais ça ne fonctionne pas comme je voudrais.
    Je n'ai pas fait les choses comme il faut !?

  4. #4
    Membre du Club Avatar de smooncef
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    118
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 118
    Points : 66
    Points
    66
    Par défaut
    C'est bon, j'ai trouvé, il fallait placer les variables à chaque début d'occurences. J'ai testé et ça fonctionne, voir solution ci-dessous :

    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    @ECHO off
    
    @SET REPONSE=
    
    :debut
    @SET REPONSE=
    CLS
    @ECHO Voulez-vous detacher les bases de donnees ? Y or N
    @SET /P REPONSE=Reponse : 
    @IF '%REPONSE%' == '' GOTO debut
    @IF /I %REPONSE% == y GOTO suite
    @IF /I %REPONSE% == n GOTO quitter
    
    :quitter
    @SET REPONSE=
    CLS
    @echo Voulez-vous quitter le programme ? Y or N
    @SET /P REPONSE=Reponse : 
    @IF '%REPONSE%' == '' GOTO quitter
    @IF /I %REPONSE% == y GOTO eof
    @IF /I %REPONSE% == n GOTO debut
    
    :suite
    CLS
    @ECHO Lancement du detachement des bases futiles !
    osql -E -Q DetacheLesDB
    
    ERASE D:\BasesClients\LOG\*.ldf
    ERASE D:\BasesClients\DATA\*.mdf
    
    PAUSE
    
    :eof

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. problème pour éviter les doublons dans une table
    Par bonnet85 dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 19/02/2008, 04h35
  2. comment faire pour éviter les scroller dans une page quelque soit la résolution
    Par ghou67 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 09/11/2007, 09h15
  3. Réponses: 8
    Dernier message: 29/03/2007, 14h48
  4. Réponses: 8
    Dernier message: 27/01/2007, 13h44
  5. [SGBD] Parser une variable pour mettre données dans bdd MySQL
    Par winnie82 dans le forum SQL Procédural
    Réponses: 9
    Dernier message: 15/03/2006, 17h20

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