-2

如何在应用程序启动时检查sqlite中是否有数据如果数据库中有数据,那么它应该上传其他方式正常工作的应用程序

我将使用 post 上传这些数据,并使用 php 将数据上传到服务器。

     + (void) getInitialDataToDisplay:(NSString *)dbPath {

CereniaAppDelegate *appDelegate = (CereniaAppDelegate *)[[UIApplication sharedApplication] delegate];

if (sqlite3_open([dbPath UTF8String], &database) == SQLITE_OK) {

    const char *sql = "select response_Id,question_id,answer_option,answer_text,update_date_time from survey_question_responses";



    sqlite3_stmt *selectstmt;
    if(sqlite3_prepare_v2(database, sql, -1, &selectstmt, NULL) == SQLITE_OK) {

        while(sqlite3_step(selectstmt) == SQLITE_ROW) {

            NSInteger primaryKey = sqlite3_column_int(selectstmt, 0);
            Coffee *coffeeObj = [[Coffee alloc] initWithPrimaryKey:primaryKey];
            coffeeObj.question_Id = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 1)];
            coffeeObj.answer_text = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 2)];
            coffeeObj.answer_option = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt,3)];

            coffeeObj.update_date_time = [NSString stringWithUTF8String:(char *)sqlite3_column_text(selectstmt, 4)];
            int count=[appDelegate.coffeeArray count];

            NSLog(@"count is beofore getting values %d",count);




            [appDelegate.coffeeArray addObject:coffeeObj];



            int countone=[appDelegate.coffeeArray count];

            NSLog(@"count is after getting values %d",countone);

            [coffeeObj release];
        }
       }
     }
     else
    sqlite3_close(database); //Even though the open call failed, close the    database connection to release all the memory.
       }
4

1 回答 1

0

您可以通过以下方式获取数据库中存在的行数:

SELECT COUNT(*) FROM table;

如果它返回 0 那么你的表是空的。

//更新...................

      const char *sqlQuery="Select count(*)from yourTable";
    if(sqlite3_prepare_v2(database, sqlQuery, -1, &queryStatement, NULL)==SQLITE_OK)
    {
        while (sqlite3_step(queryStatement)==SQLITE_ROW) 
        {

            const char *count=(const char *)sqlite3_column_text(queryStatement, 0);
           NSString *rowCount=[NSString stringWithCString:count encoding:NSASCIIStringEncoding];

       //here you will get the number of rows in string format;


        }

    }
于 2012-09-05T10:27:50.520 回答