1

我正在尝试根据本教程(CoreData此处设置索引数据库FMDB

我是ios的初学者,所以添加时可能会出错

SQLITE_ENABLE_FTS3 SQLITE_ENABLE_FTS3_PARENTHESIS 宏。

我将它们添加到其他 C 标志。

这是我的代码:

- (void) setIndexDatabase
{
    // Create (or open) our database
    NSString *dbPath = [NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES) objectAtIndex:0];
    dbPath = [dbPath stringByAppendingPathComponent:@"Index.sqlite"];

    // Using the FMDatabaseQueue ensures that we don't accidentally talk to our database concurrently from two different threads
    FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:dbPath];
    [queue inTransaction:^(FMDatabase *db, BOOL *rollback) {
        [db executeUpdate:@"CREATE VIRTUAL TABLE IF NOT EXISTS docs USING fts4(name, contents);"];
    }];

    //Add content to index
    [queue inDatabase:^(FMDatabase *db) {
        [db executeUpdate:@"INSERT INTO docs (name, contents) VALUES(?, ?);", @"doc1", @"She sells sea shells by the sea shore."];
    }];

    //Search
    __block NSMutableArray *matches = [NSMutableArray array];
    [queue inDatabase:^(FMDatabase *db) {
        FMResultSet *resultSet = [db executeQuery:@"SELECT name FROM docs WHERE docs MATCH ?", @"she*"];
        while ([resultSet next]) {
            [matches addObject:[resultSet stringForColumn:@"name"]];
        }
    }];
}

编辑:

DB 错误:1“没有这样的模块:fts4”

我在应用程序委托中的 didFinishLaunchingWithOptions 方法中调用此函数

4

2 回答 2

2

只是为了确认; 如果您的目标是 iOS 6 或更高版本,则无需构建自己的 SQLite 即可获得 FTS。

于 2014-02-11T21:59:11.830 回答
1

发生此错误是因为 SQLite 的构建不包含 FTS 模块。我尝试了另一种方法来克服它。我删除了所有关于 SQLite 和 FMDB 的文件。然后,我使用 podfile 将 FMDB 添加到我的项目中,并且成功运行。

于 2014-02-05T08:02:33.727 回答