У меня есть какая-то база данных, и я генерирую данные примерно так.
Сначала получают categoryid и categoryName из базы данных. И заголовок раздела таблицы называется categoryName.
вот пример кода
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return categoryNamesList.count;
}
-(NSString *) tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section
{
return [categoryNamesList objectAtIndex:section];
}
Я хочу сгенерировать flashcardid и имя flashcard на основе идентификатора категории. categoryid хранится в базе данных как 1,2,3.
Итак, я передаю categoryid в запросе:
select flashCardId,flashCardName from flashCardInfo where categoryId=(parameter)
В flashcardid я получаю 1,2,3, а в массиве имен flashcards я впервые получаю flashcard1, flashcard2, flashcard3, теперь я хочу сгенерировать текст в своей ячейке, например firstcategoryname в разделе 1, а затем связать имя flashcard строки затем во втором разделе имя второй категории и связанные flashcardsNames в строках. Где увеличить идентификатор категории, чтобы получить следующие имена и идентификаторы nad и как установить текст в ячейках
Теперь, как мне сгенерировать это на
Вот код; это в файле indexviewcontroller.m
.
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return categoryNamesList.count;
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return flashCardsNamesList.count;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
static NSString *CellIdentifier = @"Cell";
CustomCell *cell = (CustomCell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
cell = [[[CustomCell alloc] initWithFrame:CGRectZero reuseIdentifier:CellIdentifier] autorelease];
}
if(categoryID<listOfCategoryId.count)
{
for(int i=0;i<flashCardsNamesList.count;i++)
{
[cell.FlashCardsNames setText:[flashCardsNamesList objectAtIndex:i]];
}
categoryID++;
[self getFlashCard:categoryID];
}
return cell;
}
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
[indexTableView deselectRowAtIndexPath:indexPath animated:YES];
for(int i=0;i<flashCardsId.count;i++)
{
questionViewControllerObj = [[flashCardQuestionViewController alloc] initWithNibName:@"FlashCardQuestionView" bundle:[NSBundle mainBundle]];
[self.navigationController pushViewController:questionViewControllerObj animated:YES];
questionViewControllerObj.flashcardid = [[flashCardsId objectAtIndex:i] intValue];
questionViewControllerObj.categoryid = [[listOfCategoryId objectAtIndex:indexPath.section]intValue];
}
}
/*
- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath {
if (editingStyle == UITableViewCellEditingStyleDelete) {
}
if (editingStyle == UITableViewCellEditingStyleInsert) {
}
}
*/
/*
- (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath {
return YES;
}
*/
/*
- (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)fromIndexPath toIndexPath:(NSIndexPath *)toIndexPath {
}
*/
/*
- (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath {
return YES;
}
*/
-(NSString *) tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section
{
return [categoryNamesList objectAtIndex:section];
}
# pragma mark -
# pragma mark viewDidLoad
- (void)viewDidLoad {
[super viewDidLoad];
[self getIntialData];
self.navigationItem.title = @"Index";
indexTableView.backgroundColor = [UIColor lightGrayColor];
}
- (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];
}
- (void)viewDidAppear:(BOOL)animated {
[super viewDidAppear:animated];
}
- (void)viewWillDisappear:(BOOL)animated {
}
- (void)viewDidDisappear:(BOOL)animated {
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
}
#pragma mark -
#pragma mark Database Methods
-(void)getIntialData
{
[self getcategory];
[self getFlashCard:categoryID];
}
//getting categoryid,categoryname from the database
-(void)getcategory
{
if(listOfCategoryId!=nil)
[listOfCategoryId removeAllObjects];
else
listOfCategoryId = [[NSMutableArray alloc] init];
if(categoryNamesList!=nil)
[categoryNamesList removeAllObjects];
else
categoryNamesList = [[NSMutableArray alloc] init];
if(listOfCategoryType!=nil)
[listOfCategoryType removeAllObjects];
else
listOfCategoryType = [[NSMutableArray alloc] init];
clsDatabase *clsDatabaseObject = [[clsDatabase alloc] init];
sqlite3_stmt *dataRows = [clsDatabaseObject getDataset:"select categoryId,categoryName,categoryType from cardCategoryInfo"];
while(sqlite3_step(dataRows) == SQLITE_ROW)
{
[listOfCategoryId addObject:[NSNumber numberWithInt:sqlite3_column_int(dataRows,0)]];
[categoryNamesList addObject: [NSString stringWithUTF8String:(char *)sqlite3_column_text(dataRows,1)]] ;
[listOfCategoryType addObject:[NSNumber numberWithInt:sqlite3_column_int(dataRows,2)]];
}
sqlite3_finalize(dataRows);
[clsDatabaseObject release];
categoryID = [[listOfCategoryId objectAtIndex:categoryID] intValue];
}
//getting flashcardId and flashcard name from categoryid
-(void)getFlashCard:(int)categoryid
{
if(flashCardsId!=nil)
[flashCardsId removeAllObjects];
else
flashCardsId = [[NSMutableArray alloc] init];
if(flashCardsNamesList!=nil)
[flashCardsNamesList removeAllObjects];
else
flashCardsNamesList = [[NSMutableArray alloc] init];
NSString *martialStr=[NSString stringWithFormat:@"%d", categoryid];
NSString *queryStr=[[NSString alloc] initWithString:@"select flashCardId,flashCardName from flashCardInfo where categoryId="];
queryStr=[queryStr stringByAppendingString:martialStr];
unsigned int lengthOfString=[queryStr length];
char temp2[lengthOfString +1];
strcpy(temp2, [queryStr cStringUsingEncoding:NSUTF8StringEncoding]);
clsDatabase *clsDatabaseObject = [[clsDatabase alloc] init];
sqlite3_stmt *dataRows = [clsDatabaseObject getDataset:temp2];
while(sqlite3_step(dataRows) == SQLITE_ROW)
{
[flashCardsId addObject:[NSNumber numberWithInt:sqlite3_column_int(dataRows,0)]];
[flashCardsNamesList addObject:[NSString stringWithUTF8String:(char *)sqlite3_column_text(dataRows,1)]];
}
sqlite3_finalize(dataRows);
[clsDatabaseObject release];
}
- (void)dealloc {
[self.navigationController popViewControllerAnimated:YES];
[listOfCategoryId release];
[listOfCategoryType release];
[questionViewControllerObj release];
[categoryNamesList release];
[flashCardsNamesList release];
[flashCardsId release];
[indexTableView release];
[super dealloc];
}
@end