我在使用sqlite时遇到了一些问题。 我想在数据库中插入一些数据,但是,当我使用函数
时 sqlite3_exec(db,sql,0,0,&zErrMsg);
,
zErrMsg返回:
near '\x90' syntax error
。
代码是:
(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);
}
之前我成功插入了一些字符。但是当我这次尝试时,我失败了。问题是由于我这次使用的角色造成的吗?
sql语句是:
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
');
表结构:
create table b_1663(
Num int primary key,
b_id varchar(20),
b_sec_title varchar(50),
b_name varchar(20),
content text
);
告诉我你是否知道答案。谢谢你!
答案 0 :(得分:0)
只是一个猜测:
您可能需要引用字符串(即替换导致解析器为barf的字符),或者更好的是,使用参数化查询。参数化查询类似于:
sql="insert foo into bar values (?,?)"
sqlexec(sql, data)