我创建了我的表并使用 firefox sqlite manager 扩展插入了我的数据,保存并添加了我的 sqlitefile,它是“notifications.sqlite”,之后我编写了这段代码,但它会输出我nothing。
打开 .sqlite 文件和打开 .db 文件有什么区别吗?如何正确打开我的数据库?
*更新:*根据 friend 的评论调试后,这行有问题:
databasePath = [[NSString alloc] initWithString: [docsDir stringByAppendingPathComponent: @"notifications.sqlite"]];
之后
if ([filemgr fileExistsAtPath: databasePath ] == YES)
if 不是 YES,所以它将丢失所有内容,因此 databasePath 有点错误
我的表格如下:
CREATE TABLE "quotes_type" ("type_id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL , "content" VARCHAR)
这是我打开 .sqlite 文件的努力:
- (void)viewDidLoad{
NSArray *dirPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *docsDir = [dirPaths objectAtIndex:0];
databasePath = [[NSString alloc] initWithString: [docsDir stringByAppendingPathComponent: @"notifications.sqlite"]];
sqlite3_stmt *statement;
NSFileManager *filemgr = [NSFileManager defaultManager];
if ([filemgr fileExistsAtPath: databasePath ] == YES)
{
if (sqlite3_open([databasePath UTF8String], &contactDB) == SQLITE_OK)
{
NSString *qrycount = [NSString stringWithFormat: @"select * from quotes_type"];
const char *count_stmt = [qrycount UTF8String];
sqlite3_prepare_v2(contactDB, count_stmt, -1, &statement, NULL);
if (sqlite3_step(statement) == SQLITE_ERROR) {
NSAssert1(0,@"Error when selecting rows %s",sqlite3_errmsg(contactDB));
} else {
NSLog(@"negin");
int myid=sqlite3_column_int(statement, 0);
NSString *text = [NSString stringWithUTF8Stringchar *)sqlite3_column_text(statement,1)];
NSLog(@"myid is %d",myid);
NSLog(@"text is %@",text);
sqlite3_finalize(statement);
sqlite3_close(contactDB);
}
}
else NSLog(@"openning has problem");
}
}
您正在检查 Documents
中的数据库。但是你曾经在那里复制过吗?如果没有,你永远不会在那里找到它。您确实想检查该文件,如果找不到,请将其从 bundle 复制到 Documents
文件夹。因此,如果您在 Documents
中找不到该数据库,则应通过以下方式复制它:
NSError *error;
NSString *bundleDatabasePath = [[NSBundle mainBundle] pathForResource"notifications" ofType"sqlite"];
NSAssert(bundleDatabasePath, @"database not found in bundle");
if (![filemgr copyItemAtPath:bundleDatabasePath toPath:databasePath error:&error])
NSLog(@"%s: copyItemAtPath failure: error = %@", __FUNCTION__, error);
关于ios - 使用firefox插件创建时如何打开.sqlite文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15863488/
欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) | Powered by Discuz! X3.4 |