我正在尝试订购快速文本搜索,以便完全匹配是第一个,部分匹配是最后一个.
我创建了一个在SQLiteStudio中工作的查询:
SELECT value, 1 AS _order FROM glossfts
WHERE glossfts.value MATCH 'dog'
UNION
SELECT value, 2 AS _order FROM glossfts
WHERE glossfts.value MATCH 'dog* NOT dog'
ORDER BY _order
结果就是这样
Beware of dog 1
Disliked by everybody, not even a dog will eat 1
Bad dog 1
Creed, dogma 2
Dogs 2
Dogwood 2
这很好用但是当我在android中使用相同的查询时我才会得到
Beware of dog 1
Disliked by everybody, not even a dog will eat 1
Bad dog 1
Disliked by everybody, not even a dog will eat 2
因为它似乎在解释:
MATCH 'dog* NOT dog'
如
MATCH 'dog* not dog'
这是怎么回事?
解决方法:
Android FTS使用标准查询语法,未增强.
因此,它不会将“NOT”或“AND”识别为运算符.它实际上是尝试将它们与db列的文本相匹配.这就是为什么在Android上,你唯一的匹配来自实际文本中带有“not”的条目.
您必须使用“ – ”表示NOT,使用空格表示AND.
因此,您的语法应如下所示:
在哪里,有光泽的,有价值的,狗的,狗的,狗的
http://www.sqlite.org/fts3.html
【说明】:本文章由站长整理发布,文章内容不代表本站观点,如文中有侵权行为,请与本站客服联系(QQ:254677821)!