2

我想创建一个排序规则,以便在数据库中不区分大小写并且没有重音搜索。

这是我的代码:

static int sqlite3NoCaseNoAccentCollate(void * foo, int ll, const void *l, int rl,
                         const void *r){
    NSLog(@"comparing");
    NSString *left = [NSString stringWithCharacters:l length:ll];
    NSString *right = [NSString stringWithCharacters:r length:rl];
    NSComparisonResult rs = [left compare:right options:NSCaseInsensitiveSearch|NSDiacriticInsensitiveSearch|NSForcedOrderingSearch];

    NSLog("%d",rs);
    return rs;
}


sqlite3 *db;
if (SQLITE_OK==sqlite3_open([pathToDataBase UTF8String], &db)){
    sqlite3_create_collation(db, "MYNOCASENOACCENT", SQLITE_UTF8, NULL, &sqlite3NoCaseNoAccentCollate);
}

当我执行此查询时:

SELECT ('teste' LIKE 'testé' COLLATE MYNOCASENOACCENT)

它返回 0 而不是 1,并且从不调用我的自定义函数(我在函数中放置断点进行测试)。

当我使用“PRAGMA collat​​ion_list”列出所有排序规则时,我的自定义排序规则就存在了。

知道这个问题吗?

4

1 回答 1

0

可能为时已晚,因此简要介绍一下:

您定义了整理功能。将用于比较指定排序规则的表列。如您所见,它不适用于like 运算符。

你需要做的是定义和注册一个like函数,例如

static void utf8likeFunc(sqlite3_context *context, int argc, sqlite3_value **argv)
{
    //...
}

sqlite3_create_function(db, "like", 2, SQLITE_UTF8, (void*)&likeInfoNorm, utf8likeFunc, 0, 0);

样例函数可以在 sqlite 源代码中找到。

于 2013-09-05T10:46:53.187 回答