0
도움이 필요합니다. 나는 데이터를 저장해야하고 동시에 그들을 보여줄 app을 쓴다. 그러나 나는 문제가있다. 두 작업 모두 주 대기열에서만 작동합니다. 내가 할 수있는 것? 감사!메인 대기열에서 Sqlite 및 UI 작업 사용
이당신은 _high DISPATCH_QUEUE_PRIORITY_LOW을 사용할 수 있습니다 및 _default :
내 UI 코드
dispatch_async(dispatch_get_main_queue(), ^{
[self.hostView.hostedGraph reloadData];
});
내 DB 코드
-(BOOL)addNewMesurable:(Mesurable*)mesurable{
if (!_database) [self createDatabase];
const char *charDBpath = [_dbPath UTF8String];
if (sqlite3_open(charDBpath, &_database) == SQLITE_OK) {
char* errorMessage;
sqlite3_exec(_database, "BEGIN TRANSACTION", NULL, NULL, &errorMessage);
NSString *query =
[NSString stringWithFormat:@"insert into %@ (value , date, time) values (? , ? , ?)",[Sensor sensorNameToString:
mesurable.sensor]];
sqlite3_stmt *statement;
if (sqlite3_prepare_v2(_database, [query UTF8String], -1, &statement, NULL) == SQLITE_OK) {
sqlite3_bind_text(statement, 1, [[mesurable.value stringValue] UTF8String], -1, NULL);
sqlite3_bind_text(statement, 2, [[mesurable getStrindDate] UTF8String], -1, NULL);
sqlite3_bind_text(statement, 3, [[mesurable getStrindTime] UTF8String], -1, NULL);
//
if(sqlite3_step(statement) != SQLITE_DONE){
NSLog(@"ERROR add data from sensor - %@ ", [Sensor sensorNameToString: mesurable.sensor ]);
}
else NSLog(@"Done");
sqlite3_clear_bindings(statement);
sqlite3_reset(statement);
sqlite3_exec(_database, "PRAGMA synchronous = OFF", NULL, NULL, &errorMessage);
sqlite3_exec(_database, "PRAGMA journal_mode = MEMORY", NULL, NULL, &errorMessage);
}
sqlite3_exec(_database, "COMMIT TRANSACTION", NULL, NULL, &errorMessage);
sqlite3_finalize(statement);
sqlite3_close(_database);
}
return YES;
}