使用 FMDB 插入表失败
Posted
技术标签:
【中文标题】使用 FMDB 插入表失败【英文标题】:Insertion to table fails with FMDB 【发布时间】:2013-02-21 11:11:57 【问题描述】:我试图在应用程序 didFinishLaunchingWithOptions 的 AppDelegate 中的数据库中插入一些值,但是每次插入数据失败时。
代码
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *docsPath = [paths objectAtIndex:0];
NSString *path = [docsPath stringByAppendingPathComponent:@"db.sqlite"];
FMDatabase *database = [FMDatabase databaseWithPath:path];
[database open];
FMResultSet *results = [database executeQuery:@"select * from settings"];
if(results == nil)
NSLog(@"Creating DB");
[database beginTransaction];
[database executeUpdate:@"create table settings(id int primary key, defaultaction text, beepsound text, vibrateeffect text, level text)"];
NSString *query = [NSString stringWithFormat:@"insert into settings(id,defaultaction,beepsound,vibrateeffect,level) values (%d, '%@', '%@','%@','%@',)",11,@"auto", @"YES", @"YES", @"HIGH"];
NSLog(@" %@",path);
BOOL y= [database executeUpdate:query];
if (!y)
NSLog(@"insert failed!!");
[database commit];
[database close];
【问题讨论】:
该 API 没有为您提供任何错误消息吗?如果没有,那么你应该停止使用它,因为它是垃圾。如果是,则检索它们并报告它们。 @***foe...我已经用了很长时间了,而且效果很好。今天早上我发现了这种类型的问题。我无法理解该怎么做... 就像我说的,检索错误信息,它会给你一个线索。如果没有此错误消息,无论如何都没有人可以帮助您。 【参考方案1】:我认为问题出在您的插入查询代码中
NSString *query = [NSString stringWithFormat:@"insert into settings(id,defaultaction,beepsound,vibrateeffect,level) values (%d, '%@', '%@','%@','%@',)",11,@"auto", @"YES", @"YES", @"HIGH"];
你又添加了一个,最后在 values() 中检查并删除最后一个,它肯定会工作
NSString *query = [NSString stringWithFormat:@"insert into settings(id,defaultaction,beepsound,vibrateeffect,level) values (%d, '%@', '%@','%@','%@')",11,@"auto", @"YES", @"YES", @"HIGH"];
试试这个查询
【讨论】:
【参考方案2】:NSString *query = @"INSERT into settings(id,defaultaction,beepsound,vibrateeffect,level)
VALUES (%@, %@, %@,%@,%@)";
BOOL y = [database executeUpdate:query, [NSNumber numberWithInt:11],@"auto", @"YES", @"YES", @"HIGH"];
尝试将您的查询更改为上述查询,如果表创建成功,它将起作用。
祝你好运。
【讨论】:
以上是关于使用 FMDB 插入表失败的主要内容,如果未能解决你的问题,请参考以下文章