データベースに2つのレコードを挿入すると、両方のデータが異なりますが、データを取得してtableViewに表示すると. テーブルビューで最初のデータが2番目のデータによって上書きされ、2番目のデータがテーブルビューで2回表示されていることがわかります。
ClsMainPageAppDelegate.h
#import <UIKit/UIKit.h>
#import "DBPersonDetails.h"
@interface ClsMainPageAppDelegate : UIResponder <UIApplicationDelegate>
@property (strong, nonatomic) UIWindow *window;
@property(strong, nonatomic) DBPersonDetails *objDbPerson;
@end
ClsMainPageAppDelegate.m
#import "ClsMainPageAppDelegate.h"
#import "ClsMainPageViewController.h"
#import "ClsTermsandConditionViewController.h"
@implementation ClsMainPageAppDelegate
@synthesize objDbPerson;
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
 // Override point for customization after application launch.
 return YES;
}
DBPersonDetails.h
#import <Foundation/Foundation.h>
@interface DBPersonDetails : NSObject
@property (nonatomic, strong) NSString *dbpersonid;
@property (nonatomic, strong) NSString *dbfullName;
@property (nonatomic, strong) NSString *dbphoneNumber;
@end
DBPersonDetails.m
#import "DBPersonDetails.h"
@implementation DBPersonDetails
- (id)init
{
    self = [super init];
    if (self) {
}
return self;
}
@end
ClsChangeNetworkViewController.h
#import <UIKit/UIKit.h>
#import "ClsUpdateNetworkViewController.h"
#import <sqlite3.h>
@interface ClsChangeNetworkViewController : UIViewController
{
   NSString *databasePath;
   sqlite3 *contactDB;
}
@property (nonatomic,strong) NSString *name;
@property (nonatomic,strong) NSString *phone;
@property (weak, nonatomic) IBOutlet UILabel *HelplineLabel;
@end
ClsChangeNetworkViewController.m
#import "ClsChangeNetworkViewController.h"
#import "DBPersonDetails.h"
#import "ClsMainPageAppDelegate.h"
@interface ClsChangeNetworkViewController () <UITableViewDataSource, UITableViewDelegate>
@property (nonatomic, strong) NSMutableArray *persontableData;
@end
@implementation ClsChangeNetworkViewController
@synthesize HelplineLabel,persontableData;
- (void)viewDidLoad
{
  [super viewDidLoad];
// Do any additional setup after loading the view.
   // Get the data in database code
self.persontableData = [[NSMutableArray alloc]init];
NSString *docsDir;
NSArray *dirPaths;
// Get the documents directory
dirPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
docsDir = [dirPaths objectAtIndex:0];
// Build the path to the database file
databasePath = [[NSString alloc] initWithString: [docsDir stringByAppendingPathComponent: @"contacts.db"]];
NSString *dbPath = databasePath;
if (sqlite3_open([dbPath UTF8String], &contactDB) == SQLITE_OK)
{
    NSString *strSQL;
    strSQL = @"SELECT * FROM CONTACTS";
    const char *sql = (const char *) [strSQL UTF8String];
    sqlite3_stmt *stmt;
    if (sqlite3_prepare_v2(contactDB, sql, -1, &stmt, NULL) == SQLITE_OK)
    {
            DBPersonDetails *DBPersonDetail  = [[DBPersonDetails alloc]init];
            while (sqlite3_step(stmt) ==SQLITE_ROW)
            {
                NSString *dbid = [NSString stringWithUTF8String:(char *) sqlite3_column_text(stmt, 0)];
                NSLog(@"ID : %@",dbid);
                NSString *dbname = [NSString stringWithUTF8String:(char *) sqlite3_column_text(stmt, 1) ];
                NSLog(@"Name : %@",dbname);
                NSString *dbphone = [NSString stringWithUTF8String:(char *) sqlite3_column_text(stmt, 2) ];
                NSLog(@"Phone Number : %@",dbphone);
                DBPersonDetail.dbpersonid = dbid;
                DBPersonDetail.dbfullName = dbname;
                DBPersonDetail.dbphoneNumber = dbphone;
                NSLog(@"Data full Name  %@ ",DBPersonDetail.dbfullName);
                NSLog(@"Data Phone Number %@",DBPersonDetail.dbphoneNumber);
                [self.persontableData addObject:DBPersonDetail];
        }
    }
    sqlite3_finalize(stmt);
}
sqlite3_close(contactDB);
}
 #pragma mark TableView Delegate
 -(NSInteger) tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
     return [self.persontableData count];
}
 -(UITableViewCell *) tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *cellIdentifier = @"Identifier";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellIdentifier];
if (cell == nil) {
    cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellIdentifier];
}
DBPersonDetails *DBPersonDetail = [self.persontableData objectAtIndex:indexPath.row];
cell.textLabel.text = DBPersonDetail.dbfullName;
cell.detailTextLabel.text = DBPersonDetail.dbphoneNumber;
return cell;
}
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
DBPersonDetails *DBPersonDetail = [self.persontableData objectAtIndex:indexPath.row];
ClsMainPageAppDelegate *objDbDelegate = [[UIApplication sharedApplication]delegate];
objDbDelegate.objDbPerson = DBPersonDetail;
UIStoryboard *storybrd = self.storyboard;
ClsChangeNetworkViewController  *svc = [storybrd instantiateViewControllerWithIdentifier:@"editcontactcontrol"];
[self presentViewController:svc animated:YES completion:nil ];
}
2 つの異なる名前で 2 つのレコードを挿入しましたが、名前のデータがテーブル ビューに表示されず、2 番目の名前のデータがテーブル ビューに 2 回表示されます。viewDidLoadのクラスClsChangeNetworkViewController.mで問題が発生する可能性があります。
私の問題を解決してください。
ありがとう
