2009-12-14 6 views
0

J'ai un problème avec sqlite. Je veux insérer des données à base de données, mais, lorsque j'utilise la fonctionerreur de syntaxe sqlite3

sqlite3_exec(db,sql,0,0,&zErrMsg);,

le zErrMsg retourne:

near '\x90' syntax error.

le code est:

(void) ExecuteCommand:(NSString *)command DBRef:(sqlite3 *)db 
{ 
    const char *sql = [command UTF8String];  
    char *zErrMsg = 0; 

    sqlite3_exec(db,sql,0,0,&zErrMsg);  
    sqlite3_free(zErrMsg); 
} 

J'ai inséré quelques personnages avec succès avant. Mais quand j'essaye cette fois, j'ai échoué. Est-ce que le problème est dû aux caractères que j'utilise cette fois?

l'instruction SQL est:

insert into b_1663 values(1,'1663',' \u7b2c1\u7ae0','\u9752\u86c7',' \u7b2c1\u7ae0 

\u6211\u4eca\u5e74\u4e00\u5343\u4e09\u767e\u591a\u5c81\u3002 

\u4f4f\u5728\u897f\u6e56\u4e00\u9053\u6865\u7684\u5e95\u4e0b\u3002\u8fd9\u6865\u53eb"\u65ad\u6865"\u3002\u4ece\u524d\u5b83\u4e0d\u53eb\u65ad\u6865\uff0c\u53eb\u6bb5\u5bb6\u6865\u3002 

\u51ac\u5929\u3002\u6211\u5403\u9971\u4e86\uff0c\u5341\u5206\u6175\u5012\u5934\u5927\u7761\u3002\u7761\u5728\u8eab\u7554\u7684\u662f\u6211\u59ca\u59ca\u3002\u6211\u4eec\u76d8\u9519\u7ea0\u7f20\u7740\uff0c\u4e0d\u77e5\u4eba\u95f4\u4f55\u4e16\u3002 

"\u8fd9\u662f\u9ad8\u4eba\uff01" 

\u6211\u95ee\uff1a 

"\u548c\u5c1a\u4e5f\u662f\u4eba\uff1f" 

\u2014\u2014\u548c\u5c1a\u662f"\u4eba"\uff1f\u8fd9\u4e2a\u96c4\u4f1f\u505a\u5cb8\u7684\u548c\u5c1a\uff0c\u5e94\u8be5\u6bd4\u4eba\u9ad8\u660e\u70b9\u5427\uff1f 

\u4ed6\u4e0a\u8def\u4e86\u3002 

\u524d\u9762\u662f\u90a3\u8001\u548c\u5c1a\u3002 

'); 

la structure de la table:

create table b_1663(
    Num int primary key, 
    b_id varchar(20), 
    b_sec_title varchar(50), 
    b_name varchar(20), 
    content text 
); 

Dites-moi si vous connaissez les answer.Thanks à l'avance!

+2

Vous savez, cela aiderait énormément si nous pouvions voir l'instruction que vous essayez d'exécuter. –

+0

Vous ne nous montrez toujours pas l'instruction SQL que vous essayez d'exécuter. –

+0

Nous devons savoir ce que ** sql ** contient –

Répondre

0

Juste une supposition:

Vous avez probablement besoin de citer la chaîne (à savoir remplacer les caractères qui provoquent l'analyseur à barf), ou, mieux encore, utilisez une requête paramétrée. Les requêtes paramétrées ressemblent à quelque chose comme ceci:

+0

Si tel est le cas, l'erreur devrait se trouver sur la première ligne 'const char * sql = [commande UTF8String];' pas sur zErrMsg. – YOU

+0

quand je crée la table, cela fonctionne bien, le zErrMsg est nul. Mais quand j'insère quelque chose, il y a une erreur de syntaxe. Le problème est-il dû à l'instruction sql ou au code? – user230965

+0

erreur de syntaxe? donc vous ne pouvez pas compiler du tout ou avez des exceptions? – YOU