我正在开发 Xcode 6,Objective-C。我正在尝试使用 SQLite 来存储我的数据。但是我有一个问题,存储不是持久的。
当我启动我的程序时,我的数据库文件中有这个:
id = 0; money = 1000000; name = xx;
id = 1; money = 500200; name = bb;
现在,当我在表中插入新数据并检查我有 3 行时。但是当我关闭我的应用程序并重新打开它时,我仍然有 2 行。
这是一些代码,这是我的初始化函数:
- (id)init {
self = [super init];
if (self){
[self CopyDbToDocumentsFolder];
if (sqlite3_open([[[self GetDocumentDirectory] stringByAppendingPathComponent"Bank.sqlite"] UTF8String],
&_database) != SQLITE_OK) {
NSLog(@"Failed to open database!");
}
}
return self;
}
这是我的插入函数:
-(void)insertNSString *)cols withValuesNSString *)values intoNSString *) table{
NSString *query = [NSString stringWithFormat"INSERT INTO %@ (%@) VALUES(%@)", table, cols, values];
sqlite3_stmt *statement;
if (sqlite3_prepare_v2(_database, [query UTF8String], -1, &statement, nil) == SQLITE_OK) {
while (sqlite3_step(statement) == SQLITE_DONE);
sqlite3_finalize(statement);
}else{
NSLog(@"Failed to delete!");
sqlite3_errmsg(_database);
}
}
感谢您的帮助。
Best Answer-推荐答案 strong>
[self CopyDbToDocumentsFolder];
看起来您每次初始化该对象时都将数据库从 bundle 复制到文档目录。因此,当您再次启动应用程序时,您将覆盖您的数据库。
如果数据库不存在,您只想复制它。
关于iOS SQLite 文件保存不持久,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/30218957/
|