Elasticsearch  的查询很灵活,并且有Filter,有分组功能,还有ScriptFilter等等,所以很强大。下面上代码:

一个简单的查询,返回一个List<对象> .。

     /**
     * 根据Id 查询 SOBangg
     * @param key
     * @return
     */
    public static List findSOBanggById(String id) {
        Client client = ESTools.client;
        SearchResponse response = client.prepareSearch(MappingManager.INDEX)
        .setTypes(MappingManager.B_TYPE)
        .setSearchType(SearchType.DFS_QUERY_THEN_FETCH)
        .setQuery(QueryBuilders.termQuery("id",id))                 // Query           
        .setPostFilter(QueryBuilders.rangeQuery("age").from(12).to(18))     // Filter
        .setFrom(0).setSize(60).setExplain(true)
        .execute()
        .actionGet();
        SearchHits hits = response.getHits();
        List list = new ArrayList();
        for (SearchHit searchHit : hits) {
            Map source = searchHit.getSource();
            SOBangg entity = (SOBangg) JSONObject.toBean(JSONObject.fromObject(source) , SOBangg.class);
            list.add(entity);
        }
        return list;
    }

下面我把我整个类贴出来。

 package com.sojson.core.elasticsearch.manager;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import net.sf.json.JSONObject;

import org.elasticsearch.action.get.GetRequest;
import org.elasticsearch.action.get.GetResponse;
import org.elasticsearch.action.search.SearchRequestBuilder;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.search.SearchType;
import org.elasticsearch.client.Client;
import org.elasticsearch.common.unit.TimeValue;
import org.elasticsearch.index.query.QueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;

import com.sojson.common.model.SOBang;
import com.sojson.common.model.SOBangg;
import com.sojson.common.model.SOBanggKey;
import com.sojson.core.elasticsearch.utils.ESTools;
import com.sojson.core.mybatis.page.Pagination;

public class SelectManager {
    
    
    /**
     * 分页查询 SOBang
     * @param resultMap
     * @param pageSize
     * @param pageNo
     * @return
     */
    public static Pagination findByPage(Map resultMap,
            Integer pageSize,
            Integer pageNo){
        Pagination page = new Pagination();
        pageNo = null==pageNo?1:pageNo;
        page.setPageNo(pageNo);
        page.setPageSize(pageSize);
        
        
        Client client = ESTools.client;
        SearchRequestBuilder srb = client.prepareSearch(MappingManager.INDEX);
        srb.setSearchType(SearchType.DFS_QUERY_THEN_FETCH);
        srb.setTypes(MappingManager.TYPE);
//        srb.setQuery(resultMap);
        srb.setFrom((pageNo - 1) * pageSize).setSize(pageSize)
        .setExplain(true);
        
        SearchResponse response = srb.execute().actionGet();
        SearchHits hits = response.getHits();
        
        page.setTotalCount((int)hits.getTotalHits());
        List list = new ArrayList();
        for (SearchHit searchHit : hits) {
            Map source = searchHit.getSource();
            SOBang entity = (SOBang)JSONObject.toBean(JSONObject.fromObject(source)
                        , SOBang.class);
            list.add(entity);
        }
        page.setList(list);
        return page;
        
    }
    /**
     * 分页查询 SOBangg
     * @param resultMap
     * @param pageSize
     * @param pageNo
     * @return
     */
    public static Pagination findSOBanggByPage(Map resultMap,
            Integer pageSize,
            Integer pageNo){
        Pagination page = new Pagination();
        pageNo = null==pageNo?1:pageNo;
        page.setPageNo(pageNo);
        page.setPageSize(pageSize);
        
        
        Client client = ESTools.client;
        SearchRequestBuilder srb = client.prepareSearch(MappingManager.INDEX);
        srb.setSearchType(SearchType.DFS_QUERY_THEN_FETCH);
        srb.setTypes(MappingManager.B_TYPE);
        
        srb.setQuery(QueryBuilders.termQuery("status",0));
        srb.setFrom((pageNo - 1) * pageSize).setSize(pageSize)
        .setExplain(true);
        
        SearchResponse response = srb.execute().actionGet();
        SearchHits hits = response.getHits();
        
        page.setTotalCount((int)hits.getTotalHits());
        List list = new ArrayList();
        for (SearchHit searchHit : hits) {
            Map source = searchHit.getSource();
            SOBangg entity = (SOBangg) JSONObject
                .toBean(JSONObject.fromObject(source) , SOBangg.class);
            list.add(entity);
        }
        page.setList(list);
        return page;
        
    }
    /**
     * 根据ID查询SOBang
     * @param id
     * @return
     */
    public static SOBang findSOBangById(String id){
        GetRequest rq = new GetRequest(MappingManager.INDEX, MappingManager.TYPE, id);
        //GetResponse response = client.prepareGet(MappingManager.INDEX, MappingManager.TYPE, id);
        GetResponse response = ESTools.client.get(rq).actionGet();
        SOBang entity = null;
        //判断非空
        if(!response.isSourceEmpty()){
            Map data = response.getSource();
            entity = (SOBang)JSONObject.toBean(JSONObject.fromObject(data)
                        ,SOBang.class);
        }
        return entity;
    }
    /**
     * 根据Key 查询 SOBangg
     * @param key
     * @return
     */
    public static SOBangg findSOBanggByKey(SOBanggKey key) {
        String prefix = "%sx_x%s";
        String id = String.format(prefix, key.getId(),key.getGid());
        GetRequest rq = new GetRequest(MappingManager.INDEX, MappingManager.B_TYPE, id);
        //GetResponse response = client.prepareGet(MappingManager.INDEX, MappingManager.TYPE, id);
        GetResponse response = ESTools.client.get(rq).actionGet();
        SOBangg entity = null;
        //判断非空
        if(!response.isSourceEmpty()){
            Map data = response.getSource();
            entity = (SOBangg)JSONObject.toBean(JSONObject.fromObject(data)
                        ,SOBangg.class);
        }
        return entity;
    }
    /**
     * 根据Id 查询 SOBangg
     * @param key
     * @return
     */
    public static List findSOBanggById(String id) {
    
        Client client = ESTools.client;
        SearchResponse response = client.prepareSearch(MappingManager.INDEX)
        .setTypes(MappingManager.B_TYPE)
        .setSearchType(SearchType.DFS_QUERY_THEN_FETCH)
        .setQuery(QueryBuilders.termQuery("id",id))                 // Query
    //        .setPostFilter(QueryBuilders.rangeQuery("age").from(12).to(18))     // Filter
        .setFrom(0).setSize(60).setExplain(true)
        .execute()
        .actionGet();
        SearchHits hits = response.getHits();
        List list = new ArrayList();
        for (SearchHit searchHit : hits) {
            Map source = searchHit.getSource();
            SOBangg entity = (SOBangg) JSONObject.toBean(JSONObject.fromObject(source)
                        , SOBangg.class);
            list.add(entity);
        }
        return list;
    }
    
    
    
    public static BangDetailsBo findById(String id) {
        BangDetailsBo result = new BangDetailsBo();
        GetRequest rq = new GetRequest(MappingManager.INDEX, MappingManager.TYPE, id);
        
        GetResponse response = ESTools.client.get(rq).actionGet();
        //判断非空
        if(!response.isSourceEmpty()){
            Map data = response.getSource();
            SOBang entity = (SOBang)JSONObject.toBean(JSONObject.fromObject(data)
                        ,SOBang.class);
            result.setEntity(entity);
        }
        
        return result;
    }
}

Elasticsearch教程(九) elasticsearch 查询数据 | 分页查询的更多相关文章

  1. Oracle、MySql、SQLServer数据分页查询

    看过此博文后Oracle.MySql.SQLServer 数据分页查询,在根据公司的RegionRes表格做出了 SQLserver的分页查询语句: 别名.字段 FROM( SELECT row_nu ...

  2. Oracle、MySql、SQLServer 数据分页查询

    最近简单的对oracle,mysql,sqlserver2005的数据分页查询作了研究,把各自的查询的语句贴出来供大家学习..... (一). mysql的分页查询 mysql的分页查询是最简单的,借 ...

  3. [.NET] SQL数据分页查询

    [.NET] SQL数据分页查询 程序下载 范例下载:点此下载 原始码下载:点此下载 NuGet封装:点此下载 数据查询 开发系统时,使用C#执行SQL查询指令,就可以从SQL数据库里查询所需数据. ...

  4. 转Oracle、MySql、SQLServer 数据分页查询

    最近简单的对oracle,mysql,sqlserver2005的数据分页查询作了研究,把各自的查询的语句贴出来供大家学习..... (一). mysql的分页查询 mysql的分页查询是最简单的,借 ...

  5. CRL快速开发框架系列教程九(导入/导出数据)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  6. SQL Server -- 回忆笔记(四):case函数,索引,子查询,分页查询,视图,存储过程

    SQL Server知识点回忆篇(四):case函数,索引,子查询,分页查询,视图,存储过程 1. CASE函数(相当于C#中的Switch) then '未成年人' else '成年人' end f ...

  7. MySQL——优化嵌套查询和分页查询

    优化嵌套查询 嵌套查询(子查询)可以使用SELECT语句来创建一个单列的查询结果,然后把这个结果作为过滤条件用在另一个查询中.嵌套查询写起来简单,也容易理解.但是,有时候可以被更有效率的连接(JOIN ...

  8. SQL语句or查询,union all查询,分页查询,分组,AND查询

    一.OR查询 1.在AND多个筛选条件和一个or条件时,如果没有括号包裹,or会就近原则包裹之后的所有and条件,也就是同级的多个and条件只能对,or条件的一边起作用 2.如果or条件两边的筛选条件 ...

  9. Linq高级查询,分页查询及查询分页结合

    一.高级查询与分页查询 1.以...开头    StartsWith Repeater1.DataSource=con.Users.Where(r=>r.Nickname.StartsWith( ...

随机推荐

  1. zoj 3822 概率dp

    /* 题目大意:一个n*m的棋盘,每天放一个棋子,每行每列至少有一个棋子时结束.求达到每行每列至少有一个棋子的天数的数学期望. */ #include <iostream> #includ ...

  2. bzoj 1579: [Usaco2009 Feb]Revamping Trails 道路升级——分层图+dijkstra

    Description 每天,农夫John需要经过一些道路去检查牛棚N里面的牛. 农场上有M(1<=M<=50,000)条双向泥土道路,编号为1..M. 道路i连接牛棚P1_i和P2_i ...

  3. 高级全局API钩取 - IE连接控制

    @author: dlive @date: 2017/02/14 0x01 调试IE进程 常见网络连接库:ws2_32.dll(套接字),wininet.dll,winhttp.dll 使用Proce ...

  4. 转 linux下cat命令详解

    linux下cat命令详解 http://www.cnblogs.com/perfy/archive/2012/07/23/2605550.html 简略版: cat主要有三大功能:1.一次显示整个文 ...

  5. linux 路由表设置 之 route 指令详解【转】

    转自:http://blog.csdn.net/vevenlcf/article/details/48026965 目录(?)[-] 种路由类型 主机路由 网络路由 默认路由 配置静态路由 route ...

  6. 为何url地址不是直接发送到服务器,而是被编码后再发送

    首先,先说一下,关于为何必须将url地址,去编码后,再发送,是因为相关的协议规范:RFC 1738,定义了url地址中不能包含除了0-9的数字,大小写字母(a-zA-Z),短横线’-‘ 之外的字母.换 ...

  7. 可视化web日志分析工具Logstalgia

    https://blog.csdn.net/zrools/article/details/47250661

  8. JavaScript实现数字配对游戏

    游戏效果如下图所示: 规则: 在4X5的格子中,有随机的互不相等的10个数,每个数据有两份(也就是20个数,有两两相等的十对),随机分布在20个格子中.游戏开始,弹出二十个数的序列.每次点击格子会显示 ...

  9. git提交代码出现错误fatal: Unable to create '项目路径/.git/index.lock': File exists.

    git提交代码出现错误fatal: Unable to create '项目路径/.git/index.lock': File exists. 具体出错代码如下: 具体原因不详,在stackoverf ...

  10. codebolcks设置自动补全[转]

    熟悉使用一些开发类IDE的朋友对代码自动补全一定印象深刻,如Visual studio,eclipse等,我们在程序中定义的那一个个超长的变量函数名只需打出几个字母就可自动补全,但是在codebloc ...