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

C# Discussion :

Remplacer un caractère dans un dataset ou datatable


Sujet :

C#

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 47
    Par défaut Remplacer un caractère dans un dataset ou datatable
    Salut a tous,

    voila mon petit soucis, jusqu'à maintenant pour mes requêtes SQL quand une variable possédait un apostrophe (') je remplaçais celui ci par un autre caractère qui ne posait pas de problème pour l'exécution de la requête.

    Depuis peu j'utilise un DataSet et un DataTable pour la récupération de valeur. Pour l'envoi aucun problème je remplace toujours mais pour la récupération je ne sais pas comment remplacer étant donné que j'envoie directement mon datatable dans ma comboBox comme suite :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    DataTable dt;
    dt = BDD.GetTable("Select NoPatient, PrenomPatient From Patient Where NomPatient = '" + nom + "' Order By PrenomPatient");    //Récupération des patients
                    comboPrenomModif.ItemsSource = ((IListSource)dt).GetList();
                    comboPrenomModif.DisplayMemberPath = "PrenomPatient";
                    comboPrenomModif.SelectedValuePath = "NoPatient";
    Dans le cas ci-dessus je ne peux pas remettre l'apostrophe aux données que j'ai modifié.

    Savez vous comment je peux faire ? Si vous avez une autre solution pour la gestion de l'apostrophe je suis preneur, merci d'avance

  2. #2
    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
    Par défaut
    Citation Envoyé par warmy Voir le message
    Si vous avez une autre solution pour la gestion de l'apostrophe je suis preneur
    Il y a grosso modo 2 solutions pour gérer ce problème... et celle que tu utilises n'en fait pas partie

    Il est inutile de remplacer l'apostrophe par "un autre caractère" : il faut le remplacer par 2 apostrophes. En SQL c'est comme ça qu'on représente un apostrophe à l'intérieur d'une chaine. Mais cette méthode n'est pas géniale...

    L'autre méthode, bien meilleure, est d'utiliser des requêtes paramétrées : dans ce cas tu n'as même pas à te préoccuper du contenu de la chaine, c'est géré automatiquement. Ca marche aussi pour tous les autres types de colonne, avec des avantages évidents :
    - pour un nombre décimal, tu n'as pas besoin de te demander si la base attend une virgule ou un point comme séparateur décimal : tu affectes juste la valeur décimale au paramètre et c'est géré tout seul
    - pour une date, pas la peine non plus de se préoccuper du format : tu transmets directement la date, pas sa représentation sous forme de chaine
    - etc...

    L'utilisation de requêtes paramétrées est expliquée ici :
    http://johannblais.developpez.com/tu...s-donnees/#LIV

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 47
    Par défaut
    ok merci pour les réponses je vais essayer cela

  4. #4
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2006
    Messages
    29
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2006
    Messages : 29
    Par défaut
    Salut,

    Si ton problème est résolu n'oublie pas le !!

Discussions similaires

  1. Comment remplacer plusieurs caractères dans une chaîne?
    Par Antigonos Ier Gonatas dans le forum Général Python
    Réponses: 5
    Dernier message: 16/06/2006, 16h04
  2. [PERL]Remplacer un caractère dans on a le code ASCII
    Par LE NEINDRE dans le forum Langage
    Réponses: 4
    Dernier message: 30/09/2005, 15h13
  3. Réponses: 3
    Dernier message: 27/06/2005, 16h24
  4. Réponses: 5
    Dernier message: 25/01/2005, 14h26
  5. [CR] Chercher et remplacer un caractère dans 1 chaine
    Par franck.cvitrans dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 29/09/2004, 16h42

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