gpt4 book ai didi

mysql - 使用 ElasticSearch 使用 or 和运算符搜索多个字段

转载 作者:行者123 更新时间:2023-11-29 00:24:24 32 4
gpt4 key购买 nike

我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询:

SELECT DISTINCT t.product_id AS id 
FROM tbl_sup_price t
INNER JOIN product a ON t.product_id = a.product_id
INNER JOIN a_product_to_category a2 ON a.product_id = a2.product_id
INNER JOIN a_category_description a3 ON a2.category_id = a3.category_id
INNER JOIN tbl_sup t2 ON t.sup_id = t2.id AND (t2.status = 1)
WHERE ((t.quantity - t.reserved) > 0 AND t.is_active = 1)
AND (a.model_name LIKE '%word1%' OR t.name LIKE '%word1%')
AND (a.model_name LIKE '%word2%' OR t.name LIKE '%word2%')
ORDER BY a.price ASC

我尝试了很多选项,但没有找到我需要的东西,有人能告诉我如何解决这个问题吗?

例如:

{
"query": {
"filtered": {
"query": {
"match_all": {}
},
"filter": {
"and": [
{
"or": [
{
"fuzzy": {
"model_name": "nokian"
}
},
{
"fuzzy": {
"product_name": "nokian"
}
}
]
},
{
"or": [
{
"text": {
"model_name": "195"
}
},
{
"text": {
"product_name": "195"
}
}
]
}
]
}
}
}
}

但是如果我运行这个查询,我会遇到错误:

Parse Failure [Failed to parse source [{"query":{"filtered":{"query":{"match_all":{}},"filter":{"and":[{"or":[{"fuzzy":{"model_name":"nokian"}},{"fuzzy":{"product_name":"nokian"}}]},{"or":[{"text":{"model_name":"195"}},{"text":{"product_name":"195"}}]}]}}}}]]]; nested: QueryParsingException[[index] No filter registered for [fuzzy]]; }]

如果单词是数字 - 搜索类型必须是文本,否则 - 模糊

最佳答案

我正在解决这个问题。在 ElasticSearch 中有一个很棒的特性 function_score :

{
"query": {
"bool": {
"must": [
{
"function_score": {
"query": {
"bool": {
"should": [
{
"fuzzy": {
"model_name": "word1"
}
},
{
"fuzzy": {
"product_name": "word1"
}
}
]
}
}
}
},
{
"function_score": {
"query": {
"bool": {
"should": [
{
"fuzzy": {
"model_name": "word2"
}
},
{
"fuzzy": {
"product_name": "word2"
}
}
]
}
}
}
}
]
}
}
}

关于mysql - 使用 ElasticSearch 使用 or 和运算符搜索多个字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19631967/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com