2012-04-02 68 views
1

我嘗試只插入兩個整數變量到我的sqlite數據庫。我創建了一個名爲ups.sqlite的數據庫,它有一個表(upssTable),表中有兩列。但是當我打開/ Users/ds/Library/Application Support/iPhone Simulator/5.0/Applications/FCB4B455-4B7F-4C47-81B6-AC4121874596/SqliteDeneme.app/ups.sqlite時,ups.sqlite中沒有數據。我的代碼在這裏:Sqlite數據庫插入目標C語句

- (IBAction)buttonClick:(id)sender { 

NSFileManager *fileManager = [NSFileManager defaultManager]; 
NSError *error; 
NSString *dbPath = [self getDBPath]; 
BOOL success = [fileManager fileExistsAtPath:dbPath]; 

if(!success) { 

    NSString *defaultDBPath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:@"ups.sqlite"]; 
    success = [fileManager copyItemAtPath:defaultDBPath toPath:dbPath error:&error]; 

    if (!success) 
     NSAssert1(0, @"Failed to create writable database file with message '%@'.", [error localizedDescription]); 
} 

NSLog(@"database path %@",dbPath); 


if(!(sqlite3_open([dbPath UTF8String], &cruddb) == SQLITE_OK)) 
{ 
    NSLog(@"An error has occured."); 
} 

if(sqlite3_open([dbPath UTF8String], &cruddb) ==SQLITE_OK){ 

    NSString * str1 [email protected]"1"; 
    NSString * str2 [email protected]"1"; 


    const char *sql = "INSERT INTO upssTable (column1, column2) VALUES (?,?)"; 

    NSInteger result = sqlite3_prepare_v2(cruddb,sql, -1, &stmt, NULL); 
    NSLog(@"upss %s\n", sqlite3_errmsg(cruddb)); 

    if(result == SQLITE_OK)   
    { 
     sqlite3_bind_int(stmt, 1, [str1 integerValue]); 
     sqlite3_bind_int(stmt, 2, [str2 integerValue]); 

    } 
    else 
    { 
     NSAssert1(0, @"Error . '%s'", sqlite3_errmsg(cruddb));       
    } 
    sqlite3_reset(stmt); 
    sqlite3_finalize(stmt); 
    sqlite3_close(cruddb); 
} 
} 

- (NSString *) getDBPath { 

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES); 
NSString *documentsDir = [paths objectAtIndex:0]; 
return [documentsDir stringByAppendingPathComponent:@"ups.sqlite"]; 
} 

我該如何解決這個問題?請幫幫我。感謝您的回覆。

回答

5

您正在創建您的sqlite3語句,但您並未使用sqlite3_step()實際執行它。

此外,你似乎打開數據庫兩次?

5

你還沒有使用sqlite3_step()。試試這種方式...

sqlite3 *database; 
dbPath=[self.databasePath UTF8String]; 
    if(sqlite3_open(dbPath,&database)==SQLITE_OK) 
    { 
     const char *sqlstatement = "INSERT INTO upssTable (column1, column2) VALUES (?,?)"; 
     sqlite3_stmt *compiledstatement; 

     if(sqlite3_prepare_v2(database,sqlstatement , -1, &compiledstatement, NULL)==SQLITE_OK) 
     { 
      NSString * str1 [email protected]"1"; 
    NSString * str2 [email protected]"1"; 
     sqlite3_bind_int(compiledstatement, 1, [str1 integerValue]); 
     sqlite3_bind_int(compiledstatement, 2, [str2 integerValue]); 
     if(sqlite3_step(compiledstatement)==SQLITE_DONE) 
      { 
       NSLog(@"done"); 
      } 
      else NSLog(@"ERROR"); 
      sqlite3_reset(compiledstatement); 
    } 
    else 
    { 
     NSAssert1(0, @"Error . '%s'", sqlite3_errmsg(cruddb));       
    } 
    sqlite3_close(database); 
}