IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> ElasticSearch学习2 -> 正文阅读

[大数据]ElasticSearch学习2

QueryBuilders.boolQuery() 条件组合查询 相当于 and
QueryBuilder.matchQuery() 单个分词查询
QueryBuilder.multiMatchQuery() 指定多个字段条件匹配查询
QueryBuilder.fuzzyQuery() 模糊查询
IndicesQueryBuilder.indicesQuery() 索引查询

must 相当于 sql 中的 and
must_not 相当于 sql 中的 not
should 相当于sql 中的 or

match_all 查询所有

term 严格匹配条件,所查询的字段内容要与填入查询框搜索值一致,同时不对检索内容分词,因此如果查询内容长的话,不分词是不能匹配到结果的
range 范围查询数值或日期,gt为大于,gte为大于等于,lt小于,lte小于等于,所搜索的字段值在两个搜索框标识数值之间;
fuzzy 是弹性模糊匹配,有两种匹配模式
query_string 字符片段查询,如果是数字,则严格匹配数字,如果是字符串,则按照自身或者分片词匹配;
missing 查询没有定义该字段或者该字段值为null的数据。


/**
     * 查询sql
     * @param tableName
     * @param queryBean
     * @return Object[]
     */
    private Object[] queryData(String tableName,QueryBean queryBean) throws IOException {
        SearchRequest searchRequest = new SearchRequest(tableName);
        SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
        BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery()
                .must(QueryBuilders.termQuery("tenantId", queryBean.getTenantId()));
        RangeQueryBuilder rangQueryBuilder = QueryBuilders.rangeQuery(dateName)
                    .from(queryBean.getCreateDate())
                    .to(time)
                    .includeUpper(false);
        boolQueryBuilder.must(rangQueryBuilder );
        sourceBuilder.sort(new FieldSortBuilder("createDate").order(SortOrder.DESC));  
        //分页并将查询条件封装进sourceBuilder对象中
        Integer pageNum = queryBean.getPage();
        Integer pageSize = queryBean.getPageSize();
        // 基础索引分页,渠道索引不分页
        if (pageNum != null && pageSize != null && !isChannel) {
            sourceBuilder.from((pageNum - 1) * pageSize).size(pageSize);
        } else {
            sourceBuilder.from(0).size(CommonConstants.ES_MAX_PAGE_NUM);
        }
        sourceBuilder.query(boolQueryBuilder);
        log.info("查询sql:{}",sourceBuilder);
        searchRequest.source(sourceBuilder);
        SearchResponse searchResponse = esTemplate.getClient().search(searchRequest, RequestOptions.DEFAULT);
        if (searchResponse == null || searchResponse.getHits() == null || searchResponse.getHits().getHits() == null) {
            return null;
        }
        return searchResponse.getHits().getHits();
    }

参考地址:
https://www.cnblogs.com/huqi96/p/14875880.html
https://blog.csdn.net/qq_35530042/article/details/106674039

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-11 22:17:06  更:2022-03-11 22:18:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:53:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码