分享好友 最新资讯首页 最新资讯分类 切换频道
“完整”Lucene 搜索语法(高级查询)的示例
2024-11-06 06:53

在构造 Azure AI 搜索的查询时,可以将默认的简单查询分析程序替换为功能更强大的 Lucene 查询分析程序,以便构建专用的高级查询表达式。

“完整”Lucene 搜索语法(高级查询)的示例

Lucene 分析程序支持复杂的查询格式,比如字段范围查询、模糊搜索、中缀和后缀通配符搜索、邻近搜索、术语提升以及正则表达式搜索。 额外的功能需遵守更多处理要求,因此执行时间应该会更长一些。 在本文中,你可以逐步了解一些示例,这些示例演示了基于完整语法的查询操作。

以下查询基于 hotels-sample-index,你可以按照此快速入门中的说明进行创建。

示例查询使用 REST API 和 POST 请求来表达。 可以在 REST 客户端中粘贴并运行它们。 或者,在 Azure 门户中使用搜索资源管理器的 JSON 视图。 在 JSON 视图中,可以粘贴本文中所示的查询示例。

请求头必须具有以下值:

密钥 值 Content-Type application/json api-key ,查询或管理密钥

URI 参数必须包括具有索引名、文档集合、搜索命令和 API 版本的搜索服务终结点,类似于以下示例:

请求正文的格式应为有效的 JSON:

  • 设置为“*”时,表示一个未指定的查询,等效于 NULL 或空搜索。 它不是特别有用,但却是你可以执行的最简单的搜索,并且会显示索引中所有可检索的字段以及所有值。

  • 设置为“完整”时,会调用完整的 Lucene 查询分析程序,它是此语法的必需参数。

  • 设置为以逗号分隔的字段列表时,可用于搜索结果组合,使其只包括在搜索结果上下文中有用的字段。

  • 返回与搜索条件匹配的文档数。 在空搜索字符串上,计数将是索引中的所有文档(在 hotels-sample-index 中,数量为 50)。

    字段化搜索将单个嵌入式搜索表达式的范围限定为特定字段。 此示例搜索包含字词“hotel”的酒店名称,而不是“motel”。 可以使用 指定多个字段。

    使用此查询语法时,如果想要查询的字段在搜索表达式中,则可以省略 参数。 如果字段化搜索包含 ,则 始终优先于 。

    此查询的响应应该类似于以下示例,根据“Resort and Spa”进行筛选,返回名称中包含“hotel”的酒店,同时排除名称中包含“motel”的结果。

    搜索表达式可以是单个字词或短语,也可以是用括号括起来的更复杂的表达式,其中可以选择使用布尔运算符。 下面是部分示例:

    如果想要两个字符串评估为单个实体,请务必将短语放置在引号内,正如这个在 字段中搜索两个不同位置的情况一样。 你可能需要对引号进行转义 (),具体取决于客户端。

    在 中指定的字段必须是可搜索的字段。 如需了解如何特性化字段定义,请参阅创建索引 (REST API)。

    模糊搜索可匹配类似的字词,包括拼写错误的字词。 若要执行模糊搜索,请在单个字词的末尾追加“”波形符,后跟指定编辑距离的可选参数(介于 0 到 2 之间的值)。 例如, 或 会返回 blue、blues 和 glue。

    对此查询的响应会解析为匹配文档中的“concierge”,为简洁起见只截取了一部分:

    不直接支持短语,但你可以基于多部件短语的每个字词指定一个模糊匹配,例如 。 此查询表达式根据“laundry service”查找到 15 个匹配项。

    邻近搜索会查找在文档中相互靠近的字词。 在短语末尾插入波形符“”,后跟创建邻近边界的字数。

    此查询将搜索文档中彼此相距 5 个单词以内的字词“hotel”和“airport”。 引号经过转义 (),以保留短语:

    术语提升是指相对于不包含术语的文档,提高包含提升术语的文档排名。 若要提升字词,请使用插入符号 ,并且所搜索字词末尾还要附加提升系数(数字)。 提升系数默认为 1,虽然它必须是正数,但可以小于 1(例如 0.2)。 术语提升不同于计分配置文件,因为计分配置文件提升某些字段,而非特定术语。

    在“before”查询中,搜索“beach access”,你会注意到有七个文档匹配一个或两个字词。

    实际上只有一个文档与“access”匹配,并且因为它是唯一匹配项,所以其位置较高(第二个位置),即使该文档缺少单词“beach”。

    在“after”查询中,重试该搜索,此时会提升包含字词“beach”而非“access”的结果。 查询的人工可读版本为 。 根据你的客户端,可能需要将 表达为 。

    提升字词“beach”后,“Old Carrabelle Hotel”匹配项向下移动到第六位。

    正则表达式搜索基于正斜杠“”之间的内容查找匹配项,如在 RegExp 类中所记录的那样。

    可将通常可识别的语法用于多个 () 或单个 () 字符通配符搜索。 Lucene 查询分析器支持将这些符号与单个术语一起使用,但不能与短语一起使用。

    在此查询中,搜索包含前缀“sc”的酒店名称。 不能将 或 符号用作搜索的第一个字符。

  • 最新文章
    Optimizing Website Keywords for Improved SEO Performance
    Abstra: Optimizing website keywords is a crucial aspe of improving SEO performance. By strategically choosing and implem
    org域名代表什么 org域名是什么网站
    域名是网站的标识,一个简单易记的域名可以让访问者更容易记住您的网站。网站域名后缀有很多,比如常见的.org、.com、.net等国际
    全方位解析热门话题:深入探讨用户最关心的热点问题与解决方案
    随着人工智能技术的发展其在医疗领域的应用日益广泛。算法可以在短时间内分析大量病例数据,辅助医生实行精准诊断,升级治疗效果
    【增长】机构:预计2024年Mini LED背光产品出货增长至1379万台;天钰:AMOLED驱动芯片将于2024年Q2量产;大尺寸LCD/OLED面板供需情况改善
    1.机构:预计2024年Mini LED背光产品出货增长至1379万台2.天钰:AMOLED驱动芯片将于2024年Q2量产3.京东方终止云南OLED项目10亿元
    2025年百度广告投放最新实战指南
    在数字化营销日益重要的今天,百度广告投放已成为众多企业推广品牌、吸引潜在客户的重要手段。然而,随着市场竞争的加剧,如何高
    SEO优化站长如何提高搜索排名
    在当今竞争激烈的数字市场中,提升网站的搜索排名是每位站长的主要目标。通过有效的SEO策略,不仅可以提高网站的可见性,还能吸
    企业在线竞争力提升——专业SEO推广服务助力突破
    网站优化SEO推广服务,专注于帮助企业提升在线竞争力。通过专业技术和策略,优化网站排名,吸引潜在客户,助力企业拓展市场,实
    全面解析宏碁暗影骑士软件:提升游戏性能的利器
    在现代游戏环境中,电脑性能往往是决定玩家游戏体验的关键因素之一。对于游戏爱好者来说,拥有一款能够有效提升游戏性能的软件是
    SEO优化推广软件,点击精灵(SEO流量软件)是否真有用?
    各位亲爱的小伙伴们,今天小编要和大家一起聊聊关于SEO优化推广软件中的一员——点击精灵(SEO流量软件)。大家都知道,在如今激烈
    SEO排名神器套装全面解析,轻松驾驭网站优化
    全面解析SEO排名工具套装,涵盖关键词分析、网站结构优化、内容质量评估等功能,助您轻松提升网站排名,快速吸引更多流量。无论