NSMutableArray只打印数组中的最后一个元素而不是整个数据

时间:2012-09-06 06:19:37

标签: iphone sqlite nsmutablearray ios5

任何人都可以帮助我。我已经坚持使用这个NSMutableArray最近2-3天了。我是Objective-C的初学者,我不知道代码中的错误是什么。在我的程序中,我创建了一个sqlite数据库。它包含3个字段,我已成功将值插入db.And我正在提取这些值从db到NSMutableArray并显示这个数组。但问题是最后一个元素是显示而不是整个数据。我不明白为什么它只显示最后一个元素。我会粘贴下面的代码 - 任何人都可以检查它并帮助我。

- (void)viewDidLoad
{

   NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
   NSString *documentsDir = [documentPaths objectAtIndex:0];

   databasePath = [documentsDir stringByAppendingPathComponent:@"TDL1.db"];

   const char *dbpath = [databasePath UTF8String];

   sqlite3_stmt    *statement;

        if (sqlite3_open(dbpath, &TDLDB) == SQLITE_OK)
         {
                    NSString *querySQL = [NSString stringWithFormat: @"SELECT MYTASK, SUBTASK FROM TDL1 "];

                    const char *query_stmt = [querySQL UTF8String];



      if (sqlite3_prepare_v2(TDLDB, query_stmt, -1, &statement, NULL) == SQLITE_OK)

       {
            while (sqlite3_step(statement) == SQLITE_ROW)
              {
                     todolist2=[[NSMutableArray alloc]init];

                      NSString *mytask = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 0)];

                      NSString *subtask = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 1)];

                   todolist2 = [NSMutableArray arrayWithObjects:mytask,subtask, nil];

                       NSLog(@"THE array is:%@",todolist2);

       } 

                sqlite3_finalize(statement);
}
              sqlite3_close(TDLDB);

}
         NSLog(@"THE outside array is:%@",todolist2);
[super viewDidLoad];

}

在控制台中我得到以下输出: -

2012-09-06 11:33:23.529 TDL[823:f803] THE array is:(
    task0,
    task0
)
2012-09-06 11:33:23.532 TDL[823:f803] THE array is:(
    task1,
    task1
)
2012-09-06 11:33:23.533 TDL[823:f803] THE array is:(
    task2,
    task2
)
2012-09-06 11:33:23.534 TDL[823:f803] THE array is:(
    task3,
    task3
)
2012-09-06 11:33:23.534 TDL[823:f803] THE array is:(
    task4,
    task4
)
2012-09-06 11:33:23.535 TDL[823:f803] THE array is:(
    task5,
    task5
)
2012-09-06 11:33:23.536 TDL[823:f803] THE array is:(
   task6,
   task6
)
2012-09-06 11:33:23.537 TDL[823:f803] THE array is:(
    task6,
    task6
)
2012-09-06 11:33:23.537 TDL[823:f803] THE array is:(
    task7,
    task7
)
2012-09-06 11:33:23.538 TDL[823:f803] THE array is:(
    task7,
    task7
)
2012-09-06 11:33:23.539 TDL[823:f803] THE array is:(
    task8,
    task8
)
2012-09-06 11:33:23.539 TDL[823:f803] THE array is:(
    task9,
    task9
)
2012-09-06 11:33:23.540 TDL[823:f803] THE array is:(
   task10,
   task10
)
2012-09-06 11:33:23.540 TDL[823:f803] THE outside array is:(
   task10,
   task10
)
2012-09-06 11:33:23.541 TDL[823:f803] could not prepare statement: not an error

我想显示从task0到task10的值。如何显示?请告诉我解决方案。提前谢谢。

1 个答案:

答案 0 :(得分:1)

每次进行while (sqlite3_step(statement) == SQLITE_ROW)循环时,您只是在创建一个新的NSMutableArray。实际上你正在做两次。在while循环外移动以下行:

todolist2=[[NSMutableArray alloc]init];

然后在while循环中,而不是每次使用:

重新创建一个新数组
todolist2 = [NSMutableArray arrayWithObjects:mytask,subtask, nil];

改为使用:

[todolist2 addObject:myTask];
[todolist addObject:subTask];

这些行会将两个字符串添加到数组的末尾。