我想创建一个排序规则,以便在数据库中不区分大小写并且没有重音搜索。
这是我的代码:
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 collation_list”列出所有排序规则时,我的自定义排序规则就存在了。
知道这个问题吗?