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

SQLite Discussion :

Sqlite et Guillemets


Sujet :

SQLite

  1. #1
    Rédacteur
    Avatar de Viish
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2009
    Messages
    427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2009
    Messages : 427
    Points : 1 499
    Points
    1 499
    Par défaut Sqlite et Guillemets
    Bonjour,

    Je rencontre actuellement un problème avec Sqlite et l'insertion de chaines de caractères contenant entre autre des guillemets (") dans des champs TEXT.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    db.execSQL("INSERT INTO BattleStar VALUES (\"Kara \"Starbuck\" Trace\")");
    L'objectif étant ici d'obtenir Kara "Starbuck" Trace comme résultat final.

    Et ceci ne fonctionne pas à cause des guillemets autour de Starbuck.
    J'obtiens une SQLiteException syntax error.

    Comment faire ?

    Merci d'avance.

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 14
    Points : 10
    Points
    10
    Par défaut
    peut-etre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    db.execSQL("INSERT INTO BattleStar VALUES ('Kara \"Starbuck\" Trace')");
    ?

  3. #3
    Rédacteur
    Avatar de Viish
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2009
    Messages
    427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2009
    Messages : 427
    Points : 1 499
    Points
    1 499
    Par défaut
    Non, ça ne marche pas.
    En plus, je peux avoir des ' dans mes champs TEXT.

  4. #4
    Membre actif

    Inscrit en
    Décembre 2004
    Messages
    169
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 169
    Points : 225
    Points
    225
    Par défaut
    Bonjour,

    Il est normal que ta première syntaxe soit fausse car
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    db.execSQL("INSERT INTO BattleStar VALUES (\"Kara \"Starbuck\" Trace\")");
    revient à exécuter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO BattleStar VALUES ("Kara "Starbuck" Trace")
    Il te faut obtenir un doublement des guillemets dans ton SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO BattleStar VALUES ("Kara ""Starbuck"" Trace")
    Du coup je pense à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    db.execSQL("INSERT INTO BattleStar VALUES (\"Kara \"\"Starbuck\"\" Trace\")");
    Sinon je pense que si tu passes par une variable avec un sprintf() par exemple, il te sera plus simple de gérer cette difficulté.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    char *p;
    char tmp[512];
    char sql[1024];
    for(p=titre; *p ; p++, tmp++){
      if( *p=='"' ) *tmp = *p;
      *tmp = *p;
    }
    *tmp = 0;
    sprintf( sql, "INSERT INTO BattleStar VALUES (\"%s\")\n", tmp );
    db.execSQL(sql);
    Avec la variable titre qui contient ton titre et qui subit un remplacement de tous les caractères " en "" (petite boucle de remplacement simple à mettre en oeuvre). Par contre, mon exemple n'est pas fiable en ce qui concerne la taille des chaines. Attention aux débordements !

    ++

    Qu'en penses-tu ?

  5. #5
    Rédacteur
    Avatar de Viish
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2009
    Messages
    427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2009
    Messages : 427
    Points : 1 499
    Points
    1 499
    Par défaut
    Merci beaucoup, le coup des doubles \" fonctionne super.
    Code java : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    db.execSQL("INSERT INTO BattleStar VALUES (\"Kara \"\"Starbuck\"\" Trace\")");

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

Discussions similaires

  1. qui connait sqlite ?
    Par Emmanuel Lecoester dans le forum SQLite
    Réponses: 23
    Dernier message: 19/02/2010, 13h44
  2. probleme avec sqlite et guillemets
    Par jpabeille@wanadoo.fr dans le forum SQLite
    Réponses: 1
    Dernier message: 14/10/2007, 19h45
  3. problème de guillemets dans une formule shell
    Par dim_italia dans le forum VBA Access
    Réponses: 7
    Dernier message: 18/08/2003, 12h46
  4. TAGS -> attributs sans guillemets
    Par Bastet79 dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 14/08/2003, 13h01
  5. Comment coder guillemets et cotes ?
    Par Vow dans le forum XML/XSL et SOAP
    Réponses: 4
    Dernier message: 14/05/2003, 12h11

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