我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ElasticSearch实现忽略大小写模糊查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ElasticSearch实现忽略大小写模糊查询

1.引入依赖

<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-elasticsearch</artifactId>
    <version>3.2.0.RELEASE</version>
</dependency>

2.定义

import io.swagger.annotations.ApiModel;
import java.io.Serializable;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType;
import org.springframework.data.elasticsearch.annotations.Setting;


@Document(indexName = "goodsIdx", type = "goodsType")
@Data
@NoArgsConstructor
@AllArgsConstructor
@Setting(settingPath = "elastic-setting.json")
public class GoodsIndex implements Serializable {

    @Id
    private Long id;

    @Field(type = FieldType.Keyword, analyzer = "caseSensitive")
    private String name;

    @Field(type = FieldType.Text,analyzer = "ik_max_word")
    private String brief;

    @Field(type = FieldType.Text,analyzer = "ik_max_word")
    private String introduction;
}

3.定义配置文件

{
  "analysis": {
    "analyzer": {
      "caseSensitive": {
        "filter": "lowercase",
        "type": "custom",
        "tokenizer": "keyword"
      }
    }
  }
}

4.实现忽略大小写的模糊查询

    @Autowired
    private ElasticsearchRestTemplate elasticsearchRestTemplate;

    @Test
    public void testSearch() {
        String content = "abc";

        Map<Long, List<Goods>> rst = new HashMap<>();
        NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();
        BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
        BoolQueryBuilder contentQueryBuilder = QueryBuilders.boolQuery();
        WildcardQueryBuilder groupNameQueryBuilder = QueryBuilders.wildcardQuery("name", "*" + content + "*");
        MatchQueryBuilder briefMatchQueryBuilder = new MatchQueryBuilder("brief", content);
        briefMatchQueryBuilder.operator(Operator.AND);
        MatchQueryBuilder detailMatchQueryBuilder = new MatchQueryBuilder("introduction", content);
        detailMatchQueryBuilder.operator(Operator.AND);
        contentQueryBuilder
                .should(groupNameQueryBuilder)
                .should(briefMatchQueryBuilder)
                .should(detailMatchQueryBuilder)
        ;
        boolQueryBuilder.must(contentQueryBuilder);

        queryBuilder.withQuery(boolQueryBuilder);
        queryBuilder.withPageable(PageRequest.of(0, 10000));

        List<Goods> serviceGroupInfos = elasticsearchRestTemplate
                .queryForList(queryBuilder.build(), Goods.class);
    }

5.搜索语句

{
  "bool": {
    "must": [
      {
        "bool": {
          "should": [
            {
              "wildcard": {
                "groupName": {
                  "wildcard": "*银行*",
                  "boost": 1
                }
              }
            },
            {
              "match": {
                "groupBrief": {
                  "query": "银行",
                  "operator": "AND",
                  "prefix_length": 0,
                  "max_expansions": 50,
                  "fuzzy_transpositions": true,
                  "lenient": false,
                  "zero_terms_query": "NONE",
                  "auto_generate_synonyms_phrase_query": true,
                  "boost": 1
                }
              }
            },
            {
              "match": {
                "groupIntroduction": {
                  "query": "银行",
                  "operator": "AND",
                  "prefix_length": 0,
                  "max_expansions": 50,
                  "fuzzy_transpositions": true,
                  "lenient": false,
                  "zero_terms_query": "NONE",
                  "auto_generate_synonyms_phrase_query": true,
                  "boost": 1
                }
              }
            }
          ],
          "adjust_pure_negative": true,
          "boost": 1
        }
      }
    ],
    "adjust_pure_negative": true,
    "boost": 1
  }
}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ElasticSearch实现忽略大小写模糊查询

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mongodb怎么查询忽略大小写

在MongoDB中,可以使用正则表达式来实现忽略大小写的查询。具体方法如下:使用正则表达式查询:可以使用$regex操作符来指定正则表达式进行查询。在正则表达式中使用i标记来表示不区分大小写。db.collection.find({ fie
mongodb怎么查询忽略大小写
2024-04-03

Sql like模糊查询 区分大小写

Sql模糊查询,Like默认是不区分大小写的使用Like时,怎么支持大小写呢?upper、lower,只能模糊所有的内容,不能区分内容中的大小写。sqlite数据库对text字段默认是大小写敏感的,但是唯独在模糊查询时不起作用。解决方法是:查询前先执行PRAG
Sql like模糊查询 区分大小写
2021-02-16

Mysql模糊查询中是否区分大小写

这篇文章将为大家详细讲解有关Mysql模糊查询中是否区分大小写,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。COLLATE通常是和数据编码(CHARSET)相关的,一般来说每种CHARSET
2023-06-15

忽略大小写SQL LOWER函数轻松实现

在 SQL 中,可以使用 LOWER() 函数将文本转换为小写。如果要忽略大小写进行比较或操作,可以使用 LOWER() 函数将两个文本字段都转换为小写,然后进行比较或操作。例如,假设有一个名为 “customers” 的表,其中包含 “
忽略大小写SQL LOWER函数轻松实现
2024-10-24

Java 语言中实现忽略大小写的方法有哪些?(java语言忽略大小写的方法有哪些)

在Java语言中,有多种方法可以实现忽略大小写的操作。以下是一些常见的方法:方法一:使用String类的equalsIgnoreCase()方法equalsIgnoreCase()方法用于
Java 语言中实现忽略大小写的方法有哪些?(java语言忽略大小写的方法有哪些)
Java2024-12-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录