我是iPhone开发人员的新手。
我无法解决这个问题。
这是我想要执行的代码:
[self openDB];
sqlite3_stmt *statement;
NSString *sql2 = [NSString stringWithFormat:@"INSERT INTO CheckList (CLName, DateAdd, Active, Costum, Percentage, UserId) VALUES ('ola232332332324', '2012-02-03', 1, 1, NULL, 1)"];
if(sqlite3_prepare_v2(db, [sql2 UTF8String], -1, &statement, NULL) == SQLITE_OK)
{
alert1 = [[UIAlertView alloc]
initWithTitle:@"Grats" message:@"The query was executed!" delegate:self cancelButtonTitle:@"Continue" otherButtonTitles: nil];
[alert1 show];
[alert1 release];
}
else {
NSAssert(0, @"Failed to execute");
}
sqlite3_finalize(statement);
这是我用来调用db的代码:
-(NSString *) filePath {
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDir = [paths objectAtIndex:0];
return [documentsDir stringByAppendingPathComponent:@"prosegur.sqlite"];
}
-(void) openDB {
sqlite3_open([[self filePath] UTF8String], &db);
if (sqlite3_open([[self filePath] UTF8String], &db) != SQLITE_OK){
NSAssert(0, @"Failed to open db");
}
}
提前致谢,
Rodolfo Matos
编辑:尝试使用FMDB,这是代码:
FMDatabase *database = [FMDatabase databaseWithPath:@"prosegur.sqlite"];
if([database open]){
NSLog(@"yes");
[database executeUpdate:@"INSERT INTO CheckList (CLName, DateAdd, Active, Costum, UserId) VALUES ('cenas', '2012-02-0', 1, 1, 1)"];}
else
{
NSLog(@"not");
}
通过[数据库打开]验证,但它不执行查询。 有什么建议吗? 谢谢!
编辑2:已经完成了它的建议,我开始认为它创建了一个数据库并在其中执行查询,但由于它不存在任何表,它忽略了这个事实。
这是更新后的代码: NSArray * paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES); NSString * docsPath = [[paths objectAtIndex:0] retain]; NSString * path = [[docsPath stringByAppendingPathComponent:@“prosegur.sqlite”] retain];
FMDatabase *database = [FMDatabase databaseWithPath:path];
[database open];
if([database open])
{
NSLog(@"yes");
[database executeUpdate:@"INSERT INTO CheckList (CLName) VALUES (?)", @"cenas"];
}
else
{
NSLog(@"no");
}
[database close];
再次感谢! :)
答案 0 :(得分:2)
也许这是一个愚蠢的问题,但您知道sqlite3_prepare_v2
只有准备该语句并且实际上不执行它?您还需要调用sqlite3_step
来实际执行插入,
您可以使用sqlite3_exec
代替,它只执行一个语句而不执行准备/执行两步。
答案 1 :(得分:2)
我在iOS开发中使用标准sqlite3 api时遇到了很多麻烦。 查看FMDB框架。它使用起来非常简单,您可以在网上找到很多教程。
如果您不想要该框架,请尝试使用NSError
来捕获查询执行错误。
答案 2 :(得分:1)
示例示例。
+(BOOL)InsertDataInPin:(NSString *)pin
{
NSString *databasePath =Your DatabasePath;
NSString *SQL=@"INSERT INTO pincode Values(?)";
sqlite3_stmt *dataset;
if (sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK ) {
if (sqlite3_prepare_v2(database, [SQL UTF8String], -1, &dataset, NULL) == SQLITE_OK)
{
sqlite3_bind_text(dataset, 1, [pin UTF8String], -1, SQLITE_TRANSIENT);
sqlite3_step(dataset);
}
sqlite3_close(database);
}
}
答案 3 :(得分:0)
我找到了答案,如果有人遇到这样的麻烦,请查看以下链接: IPhone Development - Failed to use SQLite
感谢大家的支持!