我使用的是基于springBoot的ElasticsearchTemplate的实现;此方法相对简单!
1》pom文件如下:
org.springframework.boot spring-boot-starter-data-elasticsearch com.google.code.gson gson 2.8.02》properties里面配置连接ElasticSearch服务器,这里我使用的是单节点


3》创建所操作实体,建立索引

注意:这里省略了getter setter方法
4》基本的增加和查询操作
4.1向es里增加数据
@PostMapping("/add")
 public String addEsdata(String id,String firstName,String lastName,Integer age,String about){
 Employee employee = new Employee();
 employee.setId(id);
 employee.setFirstName(firstName);
 employee.setLastName(lastName);
 employee.setAge(age);
 employee.setAbout(about);
 employeeRepository.save(employee);
 System.err.println(“add a job”);
 return “success”;
 }
4.2查询(支持使用Data JPA的规范做查询操作)
例如:根据id查询
@Autowired
 private EmployeeRepository employeeRepository;
@GetMapping("/queryById")
 public Employee query() {
 Employee accountInfo = employeeRepository.queryEmployeeById(“1”);
 System.err.println(new Gson().toJson(accountInfo));
 return accountInfo;
 }

我这里因为service没有做任何操作 所以service层就不贴出
最后贴一个分页的实现:
/**
 * 分页
 * @param str 查询条件
 * @param currentPage 当前页
 * @param size 页面大小
 * @return
 */
 @GetMapping("/queryBypage")
 public Page queryListBypage(String str, Integer currentPage,Integer size){
 if(StringUtils.isEmpty(currentPage)){
 currentPage = 1;
 }
 if(StringUtils.isEmpty(size)){
 size = 10;
 }
 Integer offset = (currentPage-1)*size;
 System.out.println(offset+"—"+size);
 SearchQuery searchQuery = new NativeSearchQueryBuilder().withQuery(queryStringQuery(str)).withPageable(new PageRequest(offset,size)).build();
 return elasticsearchTemplate.queryForPage(searchQuery,Employee.class);
 }









