跳到主要内容

SEARCH 函数

概述

SEARCH 函数为 Apache Doris 4.0版本开始提供的统一的全文检索查询入口。它以简洁的 DSL(领域特定语言)描述查询条件,并基于倒排索引高效执行。

SEARCH 是一个返回布尔值的谓词函数,可作为过滤条件出现在 WHERE中。它接收一个 SEARCH DSL 字符串用于描述文本匹配规则,并将可匹配条件下推至倒排索引执行。

语法与语义

语法

SEARCH('<search_expression>')
  • 参数:<search_expression> — SEARCH DSL 查询表达式(字符串字面量)

用法

  • 位置:用于 WHERE,作为谓词参与行过滤
  • 返回类型:BOOLEAN(匹配为 TRUE)

当前支持语法

词项查询

  • 语法:column:term
  • 语义:在列的分词结果中匹配该词项;是否区分大小写取决于索引属性 lower_case
  • 索引建议:为该列创建带合适 parser/analyzer 的倒排索引
SELECT id, title FROM search_test_basic WHERE SEARCH('title:Machine');
SELECT id, title FROM search_test_basic WHERE SEARCH('title:Python');
SELECT id, title FROM search_test_basic WHERE SEARCH('category:Technology');

ANY 查询

  • 语法:column:ANY(term1 term2 ...)
  • 语义:列的分词结果中包含列表里任意一个词项即可(OR 语义);顺序无关,重复词忽略
  • 索引建议:为该列创建分词倒排索引(如 english/chinese/unicode
SELECT id, title FROM search_test_basic WHERE SEARCH('tags:ANY(python javascript)');
SELECT id, title FROM search_test_basic WHERE SEARCH('tags:ANY(machine learning tutorial)');

-- 边界:单值 ANY 等价于词项查询
SELECT id, title FROM search_test_basic WHERE SEARCH('tags:ANY(python)');

ALL 查询

  • 语法:column:ALL(term1 term2 ...)
  • 语义:列的分词结果中同时包含列表里所有词项(AND 语义);顺序无关,重复词忽略
  • 索引建议:为该列创建分词倒排索引(如 english/chinese/unicode
SELECT id, title FROM search_test_basic WHERE SEARCH('tags:ALL(machine learning)');
SELECT id, title FROM search_test_basic WHERE SEARCH('tags:ALL(programming tutorial)');

-- 边界:单值 ALL 等价于词项查询
SELECT id, title FROM search_test_basic WHERE SEARCH('tags:ALL(python)');

布尔操作

  • 语法:(expr) AND/OR/NOT (expr)
  • 语义:在 SEARCH 内用 ANDORNOT 组合子表达式
  • 索引建议:尽量将可匹配条件写入 SEARCH 内部以获得索引下推;其他 WHERE 条件作为过滤
SELECT id, title FROM search_test_basic
WHERE SEARCH('title:Machine AND category:Technology');

SELECT id, title FROM search_test_basic
WHERE SEARCH('title:Python OR title:Data');

SELECT id, title FROM search_test_basic
WHERE SEARCH('category:Technology AND NOT title:Machine');

复杂嵌套表达式

  • 语法:使用括号对表达式分组(例如:(expr1 OR expr2) AND expr3
  • 语义:通过括号控制布尔优先级,支持多层嵌套
  • 索引建议:同上
SELECT id, title FROM search_test_basic
WHERE SEARCH('(title:Machine OR title:Python) AND category:Technology');

SELECT id, title FROM search_test_basic
WHERE SEARCH('tags:ANY(python javascript) AND (category:Technology OR category:Programming)');

多列搜索

  • 语法:column1:term OR column2:ANY(...) OR ...
  • 语义:在单条表达式中跨多列匹配;每列按其索引/分词配置生效
  • 索引建议:为涉及到的每一列建立合适的倒排索引
SELECT id, title FROM search_test_basic
WHERE SEARCH('title:Python OR tags:ANY(database mysql) OR author:Alice');

SELECT id, title FROM search_test_basic
WHERE SEARCH('tags:ALL(tutorial) AND category:Technology');

EXACT 查询(严格等值匹配)

  • 语法:column:EXACT(text)
  • 语义:按列的完整值进行精确匹配;区分大小写;不匹配部分词项
  • 索引建议:该列建议同时建立未分词倒排索引(不设置 parser),用于 EXACT 加速

示例:

SELECT id
FROM t
WHERE SEARCH('content:EXACT(machine learning)');

Variant 子列查询

  • 语法:variant_col.sub.path:term
  • 语义:通过点号路径访问 VARIANT 子列进行匹配;匹配行为遵循该 VARIANT 列上索引/分析器的配置
  • 支持布尔组合、ANY/ALL、嵌套路径;不存在的子列不返回匹配

示例:

SELECT id
FROM test_variant_search_subcolumn
WHERE SEARCH('properties.message:alpha');

示例

-- 同时建立分词与未分词倒排索引
CREATE TABLE t (
id INT,
content STRING,
INDEX idx_untokenized(content) USING INVERTED,
INDEX idx_tokenized(content) USING INVERTED PROPERTIES("parser" = "standard")
);

-- 严格等值匹配(使用未分词索引)
SELECT id, content
FROM t
WHERE SEARCH('content:EXACT(machine learning)')
ORDER BY id;

-- EXACT 不匹配部分词项
SELECT id, content
FROM t
WHERE SEARCH('content:EXACT(machine)')
ORDER BY id;

-- ANY/ALL 使用分词索引
SELECT id, content FROM t WHERE SEARCH('content:ANY(machine learning)') ORDER BY id;
SELECT id, content FROM t WHERE SEARCH('content:ALL(machine learning)') ORDER BY id;

-- 对比 EXACT 与 ANY
SELECT id, content FROM t WHERE SEARCH('content:EXACT(deep learning)') ORDER BY id;
SELECT id, content FROM t WHERE SEARCH('content:ANY(deep learning)') ORDER BY id;

-- 组合条件
SELECT id, content
FROM t
WHERE SEARCH('content:EXACT(machine learning) OR content:ANY(intelligence)')
ORDER BY id;

-- 带 VARIANT 列与倒排索引
CREATE TABLE test_variant_search_subcolumn (
id BIGINT,
properties VARIANT<PROPERTIES("variant_max_subcolumns_count"="0")>,
INDEX idx_properties (properties) USING INVERTED PROPERTIES (
"parser" = "unicode",
"lower_case" = "true",
"support_phrase" = "true"
)
);

-- 单词查询
SELECT id
FROM test_variant_search_subcolumn
WHERE SEARCH('properties.message:alpha')
ORDER BY id;

-- AND / ALL 查询
SELECT id
FROM test_variant_search_subcolumn
WHERE SEARCH('properties.message:alpha AND properties.message:beta')
ORDER BY id;

SELECT id
FROM test_variant_search_subcolumn
WHERE SEARCH('properties.message:ALL(alpha beta)')
ORDER BY id;

-- 不同子列 OR 查询
SELECT id
FROM test_variant_search_subcolumn
WHERE SEARCH('properties.message:hello OR properties.category:beta')
ORDER BY id;

当前限制

  • SEARCH() 暂不支持短语、前缀、通配符、正则查询
  • SEARCH() 暂不支持范围/列表查询
  • 不支持的模式可能降级为词项查询

可使用标准操作符或文本检索算子替代:

-- 通过算子进行短语检索
SELECT * FROM t WHERE content MATCH_PHRASE '全文检索';

-- 通过 SQL 进行范围过滤
SELECT * FROM t WHERE created_at >= '2024-01-01';