第一次正常工作,下次出现DB锁定问题

时间:2012-02-27 05:58:03

标签: iphone sqlite ios4

请找到以下功能。这是第一次正常工作。

我的意思是,当我添加文本时它第一次有效,然后当我再次尝试添加新文本时,它会让我感觉像是"数据库已被锁定"。

我不确定第一次不再有效吗?

请告诉我代码中的问题。

//==================================================================
- ( BOOL ) addNewSimpleTemplates:(NSString*)dbPath:(NSString*)title{
//==================================================================

  BOOL returnVal = NO;

  NSString *maxValuePosition;

  if (sqlite3_open([dbPath UTF8String], &database) == SQLITE_OK) 
  {
    NSString *selectSQL = [NSString stringWithFormat:@"select MAX(pr.position) FROM phrase_reference pr inner join storyboard_main_categories smc on smc.id = pr.main_category_id where smc.category_name = %@", @"'Simple Templates'"];

    const char *sql = [selectSQL UTF8String];

    sqlite3_stmt *selectStmt;

    if(sqlite3_prepare_v2(database, sql, -1, &selectStmt, NULL) == SQLITE_OK){

      while(sqlite3_step(selectStmt) == SQLITE_ROW) 
      {     
        //
        char *localityChars = (char*)sqlite3_column_text(selectStmt, 0);
        if (localityChars == NULL)
          maxValuePosition = nil;
        else
          maxValuePosition = [NSString stringWithUTF8String: localityChars];

          // increment the postion value
          int postion = [maxValuePosition intValue] + 1;

          NSLog(@"%d look here %@ gtitle", postion , title);

          selectStmt = nil;

          //saving a new simple phrase is started here
          sql = "insert into storyboard_phrases(phrase) Values(?)";

          if(sqlite3_prepare_v2(database, sql, -1, &selectStmt, NULL) == SQLITE_OK){

              sqlite3_bind_text(selectStmt, 1, [title UTF8String], -1, SQLITE_TRANSIENT);
          }

          if(sqlite3_step(selectStmt) != SQLITE_DONE ) {

              NSLog( @"Error: %s just here itself", sqlite3_errmsg(database) );

          } else {
              NSLog( @"Insert into row id = %d", sqlite3_last_insert_rowid(database));

              ///

              int phrase_id = sqlite3_last_insert_rowid(database);

              int sub_category_id = 0;

              selectStmt = nil;

              NSString *selectSQL = [NSString stringWithFormat:@"select id from storyboard_main_categories where category_name = %@", @"'Simple Templates'"];       

              sql = [selectSQL UTF8String]; 

              if(sqlite3_prepare_v2(database, sql, -1, &selectStmt, NULL) == SQLITE_OK) 
              {         
                  while(sqlite3_step(selectStmt) == SQLITE_ROW) 
                  {                 
                      char *localityChars = (char*)sqlite3_column_text(selectStmt, 0);

                      NSString* main_category_id = [NSString stringWithUTF8String: localityChars];

                      sql = "insert into phrase_reference (phrase_id, sub_category_id,main_category_id, position) Values(?,?,?,?)";

                      if(sqlite3_prepare_v2(database, sql, -1, &selectStmt, NULL) == SQLITE_OK){

                          sqlite3_bind_int(selectStmt, 1, phrase_id);

                          sqlite3_bind_int(selectStmt, 2, sub_category_id);

                          sqlite3_bind_int(selectStmt, 3, [main_category_id intValue]);

                          sqlite3_bind_int(selectStmt, 4, postion);

                      }

                      if(sqlite3_step(selectStmt) != SQLITE_DONE ) {
                          NSLog( @"Error: %s", sqlite3_errmsg(database) );
                      }else {
                          NSLog( @"Insert into row id = %d", sqlite3_last_insert_rowid(database));
                          returnVal = YES;
                      }
                  }
              }
              sqlite3_finalize(selectStmt);

              selectStmt = nil;


              /////
          }
      }
    }
    sqlite3_finalize(selectStmt);

  }
    NSLog(@"sdsdfsdsd closed");
  sqlite3_close(database);

  return returnVal;

}

1 个答案:

答案 0 :(得分:0)

我不会深入你的代码,但要确保 -

Dont forget to finalize the statements before close the database.
And do reset after every execution of the sqlite3 statement 

你没有在任何地方使用重置声明..尝试使用重置声明..