データベースのエントリを更新すると、ステートメントが機能し、データベースでコードが更新されます。データベースが保存されていないにもかかわらず、アプリを閉じて再度開いた場合。一時データベースを作成し、アプリが読み取っているデータベースに実際に保存しないようです。
これが私のコードです:
-(void)updateDatabase:(int)Level andPlayer:(int)questionID{
DataClass *obj=[DataClass getInstance];
//NSFileManager *filemgr = [NSFileManager defaultManager];
NSString* Database =[NSString stringWithFormat:@"levelProgress.db"];
NSString* databaseP = [[[NSBundle mainBundle]resourcePath]stringByAppendingPathComponent:Database];
databasePath = [[NSString alloc]initWithString:databaseP];
const char *dbpath = [databasePath UTF8String];
sqlite3_stmt *statement;
if (sqlite3_open(dbpath, &questionDB) == SQLITE_OK) {
NSString *querySQL = [NSString stringWithFormat:@"UPDATE levelProgress SET completed_questions=completed_questions+1 WHERE level=%d", obj.levelSelected];
const char *query_stmt = [querySQL UTF8String];
sqlite3_prepare_v2(questionDB, query_stmt, -1, &statement, NULL);
if(sqlite3_step(statement)==SQLITE_DONE){
NSLog(@"update worked");
}else{
NSLog(@"did not work");
}
sqlite3_finalize(statement);
sqlite3_close(questionDB);
}
}
これについての助けをいただければ幸いです。