Problem with inserting data into a table

前端 未结 2 1337
迷失自我
迷失自我 2021-01-20 04:28

sqlite3 *database; sqlite3_stmt *statement; NSString *dPath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:@\"UserData.sqlite\"]; const c

相关标签:
2条回答
  • 2021-01-20 05:01

    try executing commit, so setting the db to autocommit

    // COMMIT
      const char *sql2 = "COMMIT TRANSACTION";
      sqlite3_stmt *commit_statement;
      if (sqlite3_prepare_v2(database, sql2, -1, &commit_statement, NULL) != SQLITE_OK) {
        NSAssert1(0, @"Error Message: '%s'.", sqlite3_errmsg(database));
      }
      success = sqlite3_step(commit_statement);
      if (success != SQLITE_DONE) {
        NSAssert1(0, @"Error Message: '%s'.", sqlite3_errmsg(database));
      }
    }
    
    0 讨论(0)
  • 2021-01-20 05:22

    I am afraid why You are performing INSERT operation on db which is in your application bundle. Try using this sample code Which I am sure might be useful to you

    -(void)checkAndCreateDB {
        NSString* databaseName = @"MasterDB.sqlite";
        NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
        NSString *documentsDir = [documentPaths objectAtIndex:0];
        databasePath = [documentsDir stringByAppendingPathComponent:databaseName];
        BOOL success1;
        NSFileManager *fileManager = [NSFileManager defaultManager];
        success = [fileManager fileExistsAtPath:databasePath];
        if(success) return;
        NSString *databasePathFromApp = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:databaseName];
        [fileManager copyItemAtPath:databasePathFromApp toPath:databasePath error:nil];
    }
    
    -(void)insertData{
    
        sqlite3 *database;
        sqlite3_stmt *statement; 
        if(sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK)
        {
    
            NSString *insertSQL = [NSString stringWithFormat: @"INSERT INTO User (uId,userName) VALUES (\"%d\", \"%@\")",1,@"RAHUL"];
            const char *insert_stmt = [insertSQL UTF8String];
            sqlite3_prepare_v2(database, insert_stmt, -1, &statement, NULL);
    
            if(sqlite3_step(statement)==SQLITE_DONE) 
            {
                UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Add Record" message:@"Contact Added" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];    
                [alert show];
                [alert release];
                alert=nil;
    
            }
            else 
            {
                UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"record" message:@"record not created" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];   
                [alert show];
                [alert release];
                alert=nil;
            }   
            // Release the compiled statement from memory
            sqlite3_finalize(statement);    
            sqlite3_close(database);
        }
    }
    

    Here I have copied MasterDB.sqlite file in My Project resource folder . While you are running the application we normally copy the DB in application document folder and then perform any READ/WRITE operation. Its a bear minimum code performing an INSERT opertaion all you need to do is call CheckAndCreatreDB followed by insertData Function. The variable databasePath is declared in .h file for class containing these methods.

    Hope this helps !!

    0 讨论(0)
提交回复
热议问题