我正在使用 sqlite3 作为 ios 项目的数据库,并希望执行 if exists 语句以查看对象是否存在,如果存在,则更新或插入。
我正在使用这个函数来查询数据库
-(void)updateStatus:(NSString *)queryString {
    NSString    *docsDir;
    NSArray     *dirPaths;
    dirPaths    = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    docsDir     = [dirPaths objectAtIndex:0];
    m_singleton = [Singleton sharedSingleton];
    strDatabasePath         = [NSString stringWithString:[docsDir stringByAppendingPathComponent:@"BorneoMotors.db"]];
    NSFileManager *filemgr  = [NSFileManager defaultManager];
    if ([filemgr fileExistsAtPath: strDatabasePath] == YES)
    {
        const char *dbpath = [strDatabasePath UTF8String];
        if (sqlite3_open(dbpath, &sqlDatabase) == SQLITE_OK)
        {
            const char* beginString = "BEGIN;";
            sqlite3_stmt *compiledstatement;
            sqlite3_prepare_v2(sqlDatabase, beginString, -1, &compiledstatement, NULL);
            if (sqlite3_step(compiledstatement) == SQLITE_DONE) {}
            else NSLog(@"Failed!");
            sqlite3_finalize(compiledstatement);
            NSLog(@"QUERY : %@",queryString);
            const char *selectStatement = [queryString UTF8String];
            sqlite3_prepare_v2(sqlDatabase, selectStatement, -1, &compiledstatement, NULL);
            //sqlite3_bind_text(compiledstatement,1,[statusString UTF8String],-1,SQLITE_TRANSIENT);
            if (sqlite3_step(compiledstatement) == SQLITE_DONE) {}
            else NSLog(@"Failed!");
            sqlite3_finalize(compiledstatement);
            const char* endString="END;";
            sqlite3_prepare_v2(sqlDatabase, endString, -1, &compiledstatement, NULL);
            if (sqlite3_step(compiledstatement) == SQLITE_DONE) {}
            else NSLog(@"Failed!");
            sqlite3_finalize(compiledstatement);
            sqlite3_close(sqlDatabase);
        }
        else NSLog(@"Failed to open table");
    }
}
我遇到的问题是,如果存在的话,它会返回什么,我该如何继续前进。
NSString *checkstring = [NSString stringWithFormat:@"IF EXISTS (SELECT * FROM DATABASE WHERE id = %@",cars.ID];
                    DB *accessdb = [[DB alloc] init];
                    [accessdb updateStatus:checkstring];
                    if (??){
                        NSString *queryString = [NSString stringWithFormat: @"UPDATE DATABASE SET STATUS='%@' WHERE \"DATABASEID\" = '%@'", cars.status,cars.ID];
                        const char *selectStatement = [queryString UTF8String];
                        sqlite3_prepare_v2(sqlDatabase, selectStatement, -1, &statement, NULL);
                        //sqlite3_bind_text(compiledstatement,1,[statusString UTF8String],-1,SQLITE_TRANSIENT);
                        if (sqlite3_step(statement) == SQLITE_DONE) {}
                        else NSLog(@"Failed!");
                        sqlite3_finalize(statement);
                    }else{
                        insert}
如何检查对象是否存在?if exists 返回什么?需要一些指导...