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 内用
AND
、OR
、NOT
组合子表达式 - 索引建议:尽量将可匹配条件写入 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';