1

我想知道对于 SQLite 的 fts(3/4) 是否可以实现以下操作。我使用 fts3 创建了一个包含一些数据的表。

例如,如果我搜索 e*,我会得到以 ^e 开头的所有内容但是我也可以在索引/目录中搜索以 e 开头的特定单词吗?

这样我就只能得到那个词的结果了;艾略特,埃洛,嗯。

4

3 回答 3

2

FTS 引擎通过offsets虚拟功能提供该信息。

SELECT offsets(docs) FROM docs WHERE docs MATCH 'e*';

正如文档所说:

对于使用全文索引的 SELECT 查询,offsets() 函数返回一个包含一系列以空格分隔的整数的文本值。对于当前行的每个短语匹配中的每个术语,返回列表中有四个整数。每组四个整数解释如下:

  1. 术语实例出现的列号(0 表示 FTS 表的最左侧列,1 表示下一个最左侧的列,等等)。
  2. 全文查询表达式中匹配词条的词条号。查询表达式中的术语按照出现的顺序从 0 开始编号。
  3. 列中匹配项的字节偏移量。
  4. 匹配项的大小(以字节为单位)。

如何提取这些信息取决于您以及如何将代码与 SQLite 集成。

于 2010-12-23T15:41:37.437 回答
2

http://www.sqlite.org/fts3.html#section_3

       SELECT * FROM docs WHERE docs MATCH 'lin*';

将返回包含以“lin”开头的单词的文档。你只想要匹配的单词,而不是上下文?也许“片段”功能会对您有所帮助。你可能会发现这个有趣的话题:

http://www.mail-archive.com/sqlite-users@sqlite.org/msg49345.html

于 2010-12-23T15:22:45.420 回答
0

片段函数的文档对其第 6 个参数相当模糊,因为该算法使用最佳得分方法来查找片段。

尽管如此,在我的应用程序中,我得到了我在请求中寻找的原始条款的清晰摘录:

select snippet(docs,'','','', -1, 1) from docs where docs match 'e*';

它可能对您有所帮助;这个数据库内解决方案对我有帮助,因为我不想在位于数据库之外的代码中提取术语。如果您正在搜索单个单词(MATCH 查询中没有空格、OR、..),它会起作用

于 2013-11-05T21:32:32.430 回答