ターミナルを使用しMacOS
て、データベース名データベースを作成しました。sql
いくつかのレコードを挿入しました。I を使用iOS
すると、挿入された値を取得できます。
しかし、iOS
コードを使用してデータベースにレコードを挿入しようとしましたが、データベースにレコードが入力されません。
いくつかの権限を設定する必要性を設定する必要がありますか? これは私のコードです:
- (void)viewDidLoad
{
[super viewDidLoad];
[self openDB];
}
-(IBAction)save:(id)sender{
[self insertRecordIntoTableNamed:@"Contacts"
field1Value:fname.text
field2Value:lname.text
field3Value:comp.text
field4Value:email.text
field5Value:pnumber.text
field6Value:mnumber.text
field7Value:add.text
field8Value:city.text
field9Value:state.text];
}
-(void)openDB{
NSString *sqlfile=[[NSBundle mainBundle]pathForResource:@"database" ofType:@"sql"];
if(sqlite3_open([sqlfile UTF8String], &db)!= SQLITE_OK){
sqlite3_close(db);
NSLog(@"Database connected");
NSAssert(0,@"Database failed to open");
}
else
{
NSLog(@"Database connected");
}
}
-(void) insertRecordIntoTableNamed:(NSString *) tableName
field1Value:(NSString *) field1Value
field2Value:(NSString *) field2Value
field3Value:(NSString *) field3Value
field4Value:(NSString *) field4Value
field5Value:(NSString *) field5Value
field6Value:(NSString *) field6Value
field7Value:(NSString *) field7Value
field8Value:(NSString *) field8Value
field9Value:(NSString *) field9Value {
NSString *sql = [NSString stringWithFormat:@"INSERT INTO %@ VALUES ('%@','%@','%@','%@',%@,%@,'%@','%@','%@');",tableName, field1Value, field2Value,field3Value,field4Value,field5Value,field6Value,field7Value ,field8Value,field9Value];
NSLog(@"%@",sql);
// char *err;
sqlite3_stmt *statement;
if (sqlite3_prepare_v2(db, [sql UTF8String], -1, &statement, nil)== SQLITE_OK)
{
if (SQLITE_DONE!=sqlite3_step(statement))
{
sqlite3_close(db);
NSAssert(0, @"Error updating table.");
}
else{
NSLog(@"Success");
NSLog(@"%@",sql);
}
}
sqlite3_finalize(statement);
}
@end
これが私がやったことです:
CHMOD を使用してフォルダーとパスのアクセス許可を変更する
に分割
sqlite3_exec()
しsqlite3_prepare()
、sqlite3_step()
-sqlite3_finalize()
同じ出力が得られます-クエリは作成されますが、データベースにレコードは作成されません- レコード情報を取得できます