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

VB.NET Discussion :

problème nom de fichier


Sujet :

VB.NET

  1. #1
    Membre régulier Avatar de grrrkewel
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 72
    Points : 75
    Points
    75
    Par défaut problème nom de fichier
    bonjour à tous,
    mon problème est le suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
            proc.StartInfo.FileName = "GOM.exe"
             strReq = "SELECT path FROM films WHERE nom='" & ListBox1.SelectedItem & "'"
            requeteListBox(ListBox3, strReq)
            path = ListBox3.Items(0) & ListBox1.SelectedItem
            proc.StartInfo.Arguments = path
            proc.Start()
    je récupère mon chemin (path) via une requête SQL ( requeteListBox), mais lorsque mon nom de fichier comprend une apostrophe, la requête SQL plante...
    Comment puis-je remédier à ça?

    Merci d'avance
    Grrr

  2. #2
    Membre averti
    Avatar de Ogotcha
    Inscrit en
    Juillet 2008
    Messages
    232
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Juillet 2008
    Messages : 232
    Points : 398
    Points
    398
    Par défaut
    Essai avant d'executer ta requete de faire un trim ou split ou bien un substring ou encore un replace tous ceci sont des opérations que l'on peut effectué sur une variable de type string

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753

  4. #4
    Membre régulier Avatar de grrrkewel
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 72
    Points : 75
    Points
    75
    Par défaut
    Citation Envoyé par Ogotcha
    Essai avant d'executer ta requete de faire un trim ou split ou bien un substring ou encore un replace tous ceci sont des opérations que l'on peut effectué sur une variable de type string
    je vais essayé, merci
    édit : tes opérations permettent de découper un string, alors que je voudrais justement qu'il passe en un seul bloc, et non pas qu'il soit arrêté au niveau de l'apostrophe donc soit je capte pas ce que tu m'indiquai de faire, soit tant pi et merci quand même

    ouais c'est exactement ce que je cherche à faire, mais c'est en c# je crois, et donc j'arrive pas à traduire en vb, il y a des problèmes

    Code VB : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      Dim paramNom = Mycommand.CreateParameter()
            paramNom.Name = "@login"   ' ce paramètre n'existe pas avec system.data.oleDB
            paramNom.DbType = DbTypes.VarChar 'je sais pas ce que ça veut dire...
            paramNom.Direction = ParameterDirection.Input
    bref si tu pouvais éclaircir tout ça...
    merci

  5. #5
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    pour le Name qui n'existe pas dans OleDbParameter, tu peux l'ignorer (supprime simplement la ligne)
    par contre il faut que tes paramètres soient ajoutés dans l'ordre dans lequel ils sont utilisés dans la requête (s'il y en a plusieurs)
    et selon le type de BDD utilisé, la notation ne sera pas forcément "@login" mais peut-être ":login" (Oracle par exemple) ou encore simplement "?"

    DbTypes.VarChar signifie que ce paramètre est de type "texte de longueur variable"
    cf. MSDN pour plus de détails

  6. #6
    Membre régulier Avatar de grrrkewel
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 72
    Points : 75
    Points
    75
    Par défaut
    bon, ça fonctionne à peu près, je m'explique :
    j'ai codé ceci, sur la base du tuto proposé par tomlev et de ses précisions
    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
     
     
            MyConnexion.Open()
            Mycommand.CommandType = CommandType.Text
            Mycommand.CommandText = "SELECT path FROM films WHERE nom=@nom"
            'Il suffit ensuite de déclarer un magnifique paramètre SQL comme ceci :
            Dim paramNom = Mycommand.CreateParameter()
            paramNom.ParameterName = "@login"
            paramNom.DbType = DbType.StringFixedLength
            paramNom.Direction = ParameterDirection.Input
            paramNom.Value = ListBox1.SelectedItem 
     
            Mycommand.Parameters.Add(paramNom)
     
            Dim myReader As OleDbDataReader = Mycommand.ExecuteReader()
     
            ListBox3.Items.Clear()
     
            Do While myReader.Read()
                ListBox3.Items.Add(myReader.GetString(0))
     
            Loop
     
            myReader.Close()
            MyConnexion.Close()
    mon problème maintenant est que même quand "ListBox1.SelectedItem" change, la requête retourne toujours la même réponse...
    avec l'ancien système ça ne fait pas ça...
    bizarre non?
    Merci d'avance de me donner un petit coup de main, mon projet touche à sa fin

  7. #7
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    normal, à chaque fois tu rajoutes un paramètre à la même commande, mais seul le premier est utilisé...
    il faut que tu changes la valeur du paramètre déjà existant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    myCommand.Parameters("@login").Value = ListBox1.SelectedItem
    (ou quelque chose comme ça)

  8. #8
    Membre régulier Avatar de grrrkewel
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 72
    Points : 75
    Points
    75
    Par défaut
    PARFAIT


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

Discussions similaires

  1. Problème nom de fichier et date
    Par nico5065 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 02/02/2012, 21h32
  2. Problème nom de Fichier
    Par Tora21 dans le forum Play!
    Réponses: 3
    Dernier message: 06/09/2011, 11h25
  3. Problème nom de fichier généré avec une variable
    Par matlabeginer dans le forum MATLAB
    Réponses: 3
    Dernier message: 09/04/2008, 12h03
  4. Wget : problème # nom de fichier
    Par HurSG dans le forum Windows
    Réponses: 1
    Dernier message: 09/10/2007, 20h57
  5. Réponses: 3
    Dernier message: 05/03/2007, 11h13

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