任何人都可以帮助我。我已经坚持使用这个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的值。如何显示?请告诉我解决方案。提前谢谢。
答案 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];
这些行会将两个字符串添加到数组的末尾。