4

我正在使用 fmdb,但我不知道在哪里添加 db 文件。我发现这个旧答案我认为它不适合 xcode 4.2(因为我们不再有“资源”文件夹)。

我在“Lita”中创建了一个数据库,添加了扩展名 .sqlite 并添加了 db 文件,如下所示:

数据库sqlite

然后尝试使用以下

    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 tbl"];
printf("hi");
while([results next]) {
    printf("hi2");
NSString *name = [results stringForColumn:@"clm1"];
NSString *text  = [results stringForColumn:@"clm2"];        
NSLog(@"test: %@ - %@",name, text);
}
printf("done");

我得到了'嗨''完成'但从来没有'hi2'......

有人可以帮忙吗?

4

3 回答 3

6

您想将(编译的)数据库作为资源添加到项目中,然后在首次启动时将其复制到应用程序的文档文件夹中。

这是一个完成工作的示例方法,从 applicationDidFinishLaunching 调用它,并将生成的 FMDatabase * 用于所有查询。

- (FMDatabase *)openDatabase
{
    NSFileManager *fm = [NSFileManager defaultManager];
    NSString *documents_dir = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
    NSString *db_path = [documents_dir stringByAppendingPathComponent:[NSString stringWithFormat:@"database.s3db"]];
    NSString *template_path = [[NSBundle mainBundle] pathForResource:@"template_db" ofType:@"s3db"];

    if (![fm fileExistsAtPath:db_path])
        [fm copyItemAtPath:template_path toPath:db_path error:nil];
    FMDatabase *db = [FMDatabase databaseWithPath:db_path];
    if (![db open])
        NSLog(@"Failed to open database!");
    return db;
}
于 2012-04-26T12:48:02.707 回答
1

我现在正在处理同样的问题。但是要回答您的问题:文档文件夹是要在设备中使用的文件夹。

将数据库放在支持文件文件夹中。

这对我有用:

//hide status bar for full screen view
[[UIApplication sharedApplication]setStatusBarHidden:YES          withAnimation:UIStatusBarAnimationNone];

//set reference to database here
NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
            NSString *documentDir = [documentPaths objectAtIndex:0];
            self.databasePath = [documentDir stringByAppendingPathComponent:@"RPRA.sqlite"];

    [self createAndCheckDatabase];

    // Override point for customization after application launch.
    return YES;
}

//method used to create database and check if it exists

-(void) createAndCheckDatabase
{
    BOOL success;
    NSFileManager *fileManager = [NSFileManager defaultManager];
    success = [fileManager fileExistsAtPath:self.databasePath];

    if(success) return;

    //else move database into documents folder
    NSString *databasePathFromApp = [[[NSBundle mainBundle] resourcePath]
                                     stringByAppendingPathComponent:@"RPRA.db"];

    [fileManager copyItemAtPath:databasePathFromApp toPath:self.databasePath error:nil];
}
于 2012-12-02T07:47:20.940 回答
0
- (void)ensureDBFile
{
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *documentsDirectory = [paths objectAtIndex:0];
    NSString *dbFilePath = [documentsDirectory stringByAppendingPathComponent:[NSString stringWithFormat:@"retails.sqlite"]];

    NSLog(@"Database Filepath Delgate = %@", dbFilePath);

    NSFileManager *fileManager = [NSFileManager defaultManager];
    BOOL dbFileExists = [fileManager fileExistsAtPath:dbFilePath];

    if(!dbFileExists){
        //Copy the db file if it didn't exist
        NSString *bundledDbPath = [[NSBundle mainBundle] pathForResource:@"retails" ofType:@"sqlite"];

        if (bundledDbPath != nil) {
            BOOL copiedDbFile = [fileManager copyItemAtPath:bundledDbPath toPath:dbFilePath error:nil];
            if (!copiedDbFile) {
                NSLog(@"Error: Couldn't copy the db file from the bundle");
            }
        }
        else {
            NSLog(@"Error: Couldn't find the db file in the bundle");
        }
    }
    self.db = [FMDatabase databaseWithPath:dbFilePath];
    [self.db setShouldCacheStatements:NO];
    [self.db open];
    if([self.db hadError]) {
    NSLog(@"Database Error %d: %@", [self.db lastErrorCode], [self.db lastErrorMessage]);
    }
}
于 2014-07-12T04:03:01.180 回答