【发布时间】:2011-06-14 19:36:08
【问题描述】:
我需要使用 Objective C 和 iPhone SDK 将新条目写入 SQLite 数据库的帮助。
打开/关闭/读取数据库操作正常,但我不知道为什么这段代码不起作用。
-(void) testWriteToDatabase{
NSLog(@"instructions sent 3");
sqlite3 *database;
sqlite3_stmt *compiledStatement;
const char *insertSql="INSERT INTO data (name,pass,email) VALUES(?,?,?)";
NSString *userRegistered=userRegister.text;
NSLog(@"user %@",userRegistered);
NSString *passRegistered=passRegister.text;
NSLog(@"pass %@",passRegistered);
NSString *emailRegistered=emailRegister.text;
NSLog(@"email %@",emailRegistered);
sqlite3_stmt *insertStmt = nil;
if(sqlite3_open([databasePath UTF8String],&database) == SQLITE_OK) {
if(sqlite3_prepare_v2(database, insertSql, -1, &insertStmt, NULL) == SQLITE_OK){
NSLog(@"instructions sent 4");
sqlite3_bind_text(insertStmt, 1, [userRegistered UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_bind_text(insertStmt, 2, [passRegistered UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_bind_text(insertStmt, 3, [emailRegistered UTF8String], -1, SQLITE_TRANSIENT);
NSLog(@"instructions sent 5");
while (sqlite3_step(compiledStatement) == SQLITE_ROW) {
}
}
sqlite3_reset(insertStmt);
}
sqlite3_close(database);
}
老实说,我以前从未真正使用过 SQLite,但主要问题是它没有像我想要的那样向数据库“数据”添加条目。非常感谢您的帮助,干杯。
【问题讨论】:
-
你有什么理由直接与 sqlite 对话而不用关心 Core Data 吗?
-
我强烈推荐在 SQLite 周围使用 Gus Mueller 的 FMDatabase 包装类。 github.com/ccgus/fmdb
-
我希望能够将数据库下载/上传到服务器,因此没有限制。老实说,我从来没有真正考虑过:/
-
@Dave DeLong:真正的非受虐狂使用
NSCoding、NSKeyedArchiver、NSKeyedUnarchiver、NSArray和NSSet。
标签: objective-c iphone-sdk-3.0 sqlite