我试图插入一个名字到我的sqlite文件。即时通讯使用此代码,但它不工作:/SQLite iOS插入数据
-(void)InsertRecords:(NSMutableString *) txt{
if(addStmt == nil) {
const char *sql = "INSERT INTO myMovies (movieName) VALUES(?) ";
if(sqlite3_prepare_v2(database, sql, -1, &addStmt, NULL) != SQLITE_OK)
NSAssert1(0, @"Error while creating add statement. '%s'", sqlite3_errmsg(database));
else
sqlite3_bind_text(addStmt, 1, [txt UTF8String], -1, SQLITE_TRANSIENT);
}
if(SQLITE_DONE != sqlite3_step(addStmt))
NSAssert1(0, @"Error while inserting data. '%s'", sqlite3_errmsg(database));
else
sqlite3_reset(addStmt);
}
有什么错误信息? – adum
@adum错误是:断言失败 - [MyDvDsList InsertRecords:],/Users/.../MyDvDsList.m:2012-10-25 02:00:54.916 MyDvDs [28287:14003] ***终止应用程序由于未捕获异常'NSInternalInconsistencyException',原因:'创建添加语句时出错。 '内存不足'' – Rudi
当你得到“内存不足”的错误时,这实际上意味着数据库的'sqlite3'指针是'NULL'(通常无法正确打开数据库的症状)。 – Rob