2012-01-15 47 views
0

已經嘗試了8個小時,不太確定哪個部分出了問題。我知道是我試過最後一張唱片時的ID問題。它應該是ID 5,但是NSlog顯示6。 我刪除了所有的唯一ID,所以不保留關鍵問題。SLQLite'更新時出錯。 '約束失敗''

感謝您的期待。

請幫幫忙,我快瘋了........

- (id) initWithPrimaryKey:(NSInteger)pk 
{ 
    self = [super init]; 

    ID = pk; 
    isDetailViewHydrated = NO; 

    return self; 

} 

- (void)saveAllData 
{ 
    if(isDirty) { 

     if(updateStmt == nil) { 

      const char *sql = "UPDATE identifyF SET TypeName = ?, gDate = ?, Location = ?, GeoCode = ?,Note = ?, Image = ?, TypeID = ? WHERE ID = ?"; 

      if(sqlite3_prepare_v2(database, sql, -1, &updateStmt, NULL) != SQLITE_OK) 
       NSAssert1(0, @"Error while creating update statement. '%s'", sqlite3_errmsg(database)); 
     } 
     sqlite3_bind_text(addStmt, 1, [TypeName UTF8String], -1, SQLITE_TRANSIENT); 
     sqlite3_bind_text(updateStmt, 2, [DateStr UTF8String], -1, SQLITE_TRANSIENT); 
     sqlite3_bind_text(updateStmt, 3, [Location UTF8String], -1, SQLITE_TRANSIENT); 
     sqlite3_bind_text(updateStmt, 4, [GeoCode UTF8String], -1, SQLITE_TRANSIENT); 
     sqlite3_bind_text(updateStmt, 5, [Note UTF8String], -1, SQLITE_TRANSIENT); 

     //image 
     NSData *imgData = UIImagePNGRepresentation(self.Image); 
     int returnValue = -1; 
     if(self.Image != nil) 
      returnValue = sqlite3_bind_blob(updateStmt, 6, [imgData bytes], [imgData length], NULL); 
     else 
      returnValue = sqlite3_bind_blob(updateStmt, 6, nil, -1, NULL); 

     sqlite3_bind_text(updateStmt, 7, [TypeID UTF8String], -1, SQLITE_TRANSIENT); 

     sqlite3_bind_int(updateStmt, 8, ID);; 

     NSLog(@"frog name %@",TypeName); 
     NSLog(@"frog date %@",DateStr); 
     NSLog(@"location %@",Location); 
     NSLog(@"Geo code %@",GeoCode); 
     NSLog(@"note %@",Note); 
     NSLog(@"Img %@",Image); 
     NSLog(@"Type ID %@",TypeID); 
     NSLog(@"Frog ID %d",ID); 


     if(returnValue != SQLITE_OK) 
      NSLog(@"Not OK"); 

     if(SQLITE_DONE != sqlite3_step(updateStmt)) 
      NSAssert1(0, @"Error while updating. '%s'", sqlite3_errmsg(database)); 

     sqlite3_reset(updateStmt); 

     isDirty = NO; 
    } 

    isDetailViewHydrated = NO; 
} 









+ (void) getInitialDataToDisplay:(NSString *)dbPath 
{ 
    FinderAppDelegate * appDelegate = (FinderAppDelegate *)[[UIApplication sharedApplication] delegate]; 
    [appDelegate.idArray removeAllObjects]; 
    //identifyArray = [[NSMutableArray alloc] init]; 
    if (sqlite3_open([dbPath UTF8String], &database) == SQLITE_OK) { 

     const char *sql = "SELECT ID,TypeID,TypeName,Date,Location,GeoCode,Note,Image FROM identify"; 
     sqlite3_stmt *selectstmt; 
     if (sqlite3_prepare_v2(database, sql, -1, &selectstmt, NULL) == SQLITE_OK) { 

      while(sqlite3_step(selectstmt) == SQLITE_ROW) 
      { 
       NSInteger primaryKey = sqlite3_column_int(selectstmt, 0); 
       identify *my = [[identify alloc] initWithPrimaryKey:primaryKey]; 
       // my.TypeID = sqlite3_column_int(selectstmt, 1); 
       my.TypeID = [NSString stringWithUTF8String:(char *) sqlite3_column_text(selectstmt,1)]; 
       my.TypeName = [NSString stringWithUTF8String:(char *) sqlite3_column_text(selectstmt,2)]; 

       NSDateFormatter *formatter = [[NSDateFormatter alloc] init]; 
       [formatter setDateFormat:@"yyyy-MM-dd HH:mm"];   
       NSString *dateStr = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 3)]; 
       my.Date = [formatter dateFromString:dateStr];//[NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 3)]; 

       my.Location = [NSString stringWithUTF8String:(char *) sqlite3_column_text(selectstmt, 4)]; 
       my.GeoCode = [NSString stringWithUTF8String:(char *) sqlite3_column_text(selectstmt, 5)]; 
       my.Note = [NSString stringWithUTF8String:(char *) sqlite3_column_text(selectstmt, 6)]; 
       const char *raw = sqlite3_column_blob(selectstmt, 7); 
       int rawLen = sqlite3_column_bytes(selectstmt, 7); 
       NSData *data = [NSData dataWithBytes:raw length:rawLen]; 
       my.Image = [[UIImage alloc] initWithData:data]; 

       my.isDirty = NO; 

       [appDelegate.idArray addObject:my]; 
      }     
     } 
    } else sqlite3_close(database); //close db to release all memory 
} 


*** Assertion failure in -[identify saveAllData], /Users/Desmond/Desktop/Finder desmond new design 2/Finder/identify.m:241 
Current language: auto; currently objective-c 

Catchpoint 2 (exception thrown).objc[58781]: EXCEPTIONS: throwing 0x130db720 (object 0x1418bab0, a NSException) 
objc[58781]: EXCEPTIONS: searching through frame [ip=0x1cb3db3 sp=0xbffff4c0] for exception 0x130db700 
objc[58781]: EXCEPTIONS: unwinding through frame [ip=0x1cb3db3 sp=0xbffff4c0] for exception 0x130db700 
objc[58781]: EXCEPTIONS: handling exception 0x130db700 at 0x1cb3e46 
objc[58781]: EXCEPTIONS: rethrowing current exception 
objc[58781]: EXCEPTIONS: searching through frame [ip=0x1cb3e0f sp=0xbffff4c0] for exception 0x130db700 
objc[58781]: EXCEPTIONS: terminating 
objc[58781]: EXCEPTIONS: searching through frame [ip=0x1f0ef21 sp=0xbffff450] for exception 0x130db700 
objc[58781]: EXCEPTIONS: catch(id) 
objc[58781]: EXCEPTIONS: unwinding through frame [ip=0x1f0ef21 sp=0xbffff450] for exception 0x130db700 
objc[58781]: EXCEPTIONS: handling exception 0x130db700 at 0x1f0ef33 
2012-01-15 22:58:07.006 FrogFinder[58781:15b03] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Error while updating. 'constraint failed'' 
*** First throw call stack: 
(0x1d7d052 0x1f0ed0a 0x1d25a78 0x132c2db 0x93167 0x952c9 0x1d7eec9 0x9a65c2 0xbe1d54 0x1d7eec9 0x9a65c2 0x9a655a 0xa4bb76 0xa4c03f 0xa4b2fe 0x9cba30 0x9cbc56 0x9b2384 0x9a5aa9 0x27a1fa9 0x1d511c5 0x1cb6022 0x1cb490a 0x1cb3db4 0x1cb3ccb 0x27a0879 0x27a093e 0x9a3a9b 0x1f3a 0x1ed5) 

回答

1
sqlite3_bind_text(addStmt, 1, [TypeName UTF8String], -1, SQLITE_TRANSIENT); 
sqlite3_bind_text(updateStmt, 2, [DateStr UTF8String], -1, SQLITE_TRANSIENT); 
sqlite3_bind_text(updateStmt, 3, [Location UTF8String], -1, SQLITE_TRANSIENT); 
sqlite3_bind_text(updateStmt, 4, [GeoCode UTF8String], -1, SQLITE_TRANSIENT); 
sqlite3_bind_text(updateStmt, 5, [Note UTF8String], -1, SQLITE_TRANSIENT); 

肯定是第一個被前人的精力addStmt

鑑於這就是它在所示的代碼中使用的只有的地方,在顯然是爲了填充八個updateStmt變量一節,我會說這是最有可能的一個錯字或剪切和粘貼錯誤。

+0

冬青牛...........爲什麼我會錯過這個!!!!! 非常感謝你非常非常paxdiablo – Desmond 2012-01-15 13:20:28