1

私はまだObjective Cに慣れていないので、これはすべて間違っているかもしれません。

sqlite3 データベースからデータを取得し、NSObject 配列に格納しようとしています。

これが私の実装ファイルの viewDidLoad メソッドです。

- (void)viewDidLoad
{
    [super viewDidLoad];

    clients = [[NSMutableArray alloc] init];
    [self openDB];
    NSString *sql = [NSString stringWithFormat:@"SELECT * FROM clients"];
    sqlite3_stmt *statement;

    if(sqlite3_prepare_v2(db, [sql UTF8String], -1, &statement, nil)==SQLITE_OK)
    {
        while (sqlite3_step(statement)==SQLITE_ROW) {
            char *field1 = (char *) sqlite3_column_text(statement, 0);
            NSString *field1Str = [[NSString alloc]initWithUTF8String:field1];

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

            char *field3 = (char *) sqlite3_column_text(statement, 2);
            NSString *field3Str = [[NSString alloc]initWithUTF8String:field3];

            char *field4 = (char *) sqlite3_column_text(statement, 3);
            NSString *field4Str = [[NSString alloc]initWithUTF8String:field4];

            char *field5 = (char *) sqlite3_column_text(statement, 4);
            NSString *field5Str = [[NSString alloc]initWithUTF8String:field5];

            char *field6 = (char *) sqlite3_column_text(statement, 5);
            NSString *field6Str = [[NSString alloc]initWithUTF8String:field6];

            char *field7 = (char *) sqlite3_column_text(statement, 6);
            NSString *field7Str = [[NSString alloc]initWithUTF8String:field7];

            char *field8 = (char *) sqlite3_column_text(statement, 7);
            NSString *field8Str = [[NSString alloc]initWithUTF8String:field8];

            char *field9 = (char *) sqlite3_column_text(statement, 8);
            NSString *field9Str = [[NSString alloc]initWithUTF8String:field9];


            ClientObj *c1 = [[ClientObj alloc] initWithCompanyName:field1Str firstName:field2Str lastName:field3Str email:field4Str workPhone:field5Str mobilePhone:field6Str streetAddress:field7Str city:field8Str postalCode:field9Str];
        }
    }

    self.clients = [NSArray arrayWithObjects:c1,c2,c3,c4, nil];

}

while ステートメントがデータベースをループするたびに *c1 をインクリメントしようとしています。例えば。c1、c2、c3、c4

次に、上記のデータベース ループから作成された各 ClientObj をクライアント配列に追加しようとしていますが、これを行う方法がわかりません。

どんな助けやアドバイスも大歓迎です

4

1 に答える 1

2

ループの前に配列を 1 回初期化します。

self.clients = [[NSMutableArray alloc] init];

次に、各クライアント オブジェクトをループ内の配列に追加します。

while (sqlite3_step(statement) == SQLITE_ROW) {
    // ...
    ClientObj *c = [[ClientObj alloc] initWithCompanyName:field1Str firstName:field2Str lastName:field3Str email:field4Str workPhone:field5Str mobilePhone:field6Str streetAddress:field7Str city:field8Str postalCode:field9Str];
    [self.clients addObject:c];
}
于 2013-11-09T11:26:36.530 に答える