api - 如何在 Lucene 搜索语法中指定查询参数?
问题描述
我想向此https://musicbrainz.org/doc/MusicBrainz_API/Search music-API 发出获取请求。我希望它搜索专辑名称和发行格式。发行格式应该是黑胶唱片。您可以在请求的查询部分中搜索这些内容。如果我不指定任何格式,它可以正常工作,但是当我指定一种格式时,它不会注册并且仍然显示其他发布格式,例如 CD 和数字。这是我用来完成我的请求的网址:https ://musicbrainz.org/ws/2/release?query=depeche%20mode%20music%20for%20the%20massesANDformat%3AVinyl&fmt=json&limit= 10 有人知道怎么做我必须更改我的 URL,以便它只显示乙烯基格式?
解决方案
看起来该Format
字段是基于预定义值的受限列表 - 如发布格式列表页面中所示。
因此,Lucene 索引可能将此字段定义为 aStringField
而不是 a TextField
。
AStringField
定义为:
被索引但未标记的字段:整个 String 值被索引为单个标记。
这意味着您无法搜索vinyl
. 您需要使用准确的值,可以是以下值之一:
7" Vinyl
10" Vinyl
12" Vinyl
因此,为了解决这个问题,您可以构建 Lucene 查询的该部分,如下所示:
AND (format:"7\" vinyl" OR format:"10\" vinyl" format:"12\" vinyl")
文本值被"
s 包围,以确保整个术语在查询中被视为单个标记(以完全匹配索引中的单个标记)。
反斜杠用于转义"
文本中的 。
因此,整个 Lucene 查询变为:
title:"music for the masses" AND artist:"depeche mode" AND (format:"7\" vinyl" OR format:"10\" vinyl" OR format:"12\" vinyl")
当添加到 URL 时,它变成了这样:
https://musicbrainz.org/ws/2/release?query=title:"music for the masses" AND artist:"depeche mode" AND (format:"7\" vinyl" OR format:"10\" vinyl" OR format:"12\" vinyl")&fmt=json
我将以上内容粘贴到浏览器查询栏中,在 JSON 响应中返回了 8 个发布对象。
当 URL 被 URL 编码时,它最终如下所示:
https://musicbrainz.org/ws/2/release?query=title:%22music%20for%20the%20masses%22%20AND%20artist:%22depeche%20mode%22%20AND%20(format:%227\%22%20vinyl%22%20OR%20format:%2210\%22%20vinyl%22%20OR%20format:%2212\%22%20vinyl%22)&fmt=json
我在开头提到,因此格式字段(可能还有其他几个)可能被索引为字符串字段。我不知道这是事实 - 但这是我可以解释为什么我的查询有效而您的查询无效的唯一方法。所以我认为这是一个合理的假设——但我可能是错的。
推荐阅读
- jenkins - How to fix Pipeline-Script "Expected a step" error
- excel - 如何在不使用宏或 vba 的情况下根据另一个工作表中的单元格值隐藏/取消隐藏工作表
- laravel - 我在迁移数据库时遇到问题.. 使用 xampp
- javascript - Angular 7,elementRef 不正确
- javascript - 如何删除特定标签并保留其内容
- c# - 如何仅将时间插入数据库
- xamarin - 如何在 xamarin.forms 中备份 sqlite 数据库
- python - 为什么要对每个输出元素使用偏差
- laravel - laravel update 在我的本地机器上运行良好,但在实时服务器上返回错误“从空值创建默认对象”
- javascript - Javascript - 根据视频的重复更改文本