springdata -----操作ES
一:配置springdata-Es
elasticseach-JPA.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:jpa="http://www.springframework.org/schema/data/jpa"
xmlns:elasticsearch="http://www.springframework.org/schema/data/elasticsearch"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa-1.8.xsd
http://www.springframework.org/schema/data/elasticsearch
http://www.springframework.org/schema/data/elasticsearch/spring-elasticsearch-1.0.xsd
">
<context:component-scan base-package="com.sf.heros.mq.consumer"/> 扫描包
<elasticsearch:transport-client id="client" cluster-name="elasticsearch"
cluster-nodes="127.0.0.1:9300" client-transport-sniff="false"/> 配置链接端口(默认的是9200,但是我们需要与之交互,要用到配置文件里所写那个端口,我的是9300)
<elasticsearch:repositories base-package="com.sf.heros.mq.consumer.dao" springdata操作ES的 接口类
elasticsearch-template-ref="elasticsearchTemplate"/>
<bean name="elasticsearchTemplate"
class="org.springframework.data.elasticsearch.core.ElasticsearchTemplate">
<constructor-arg name="client" ref="client" /> ES操作类
</bean> </beans> 2:接口类
UserDao。java(增删改查方法 与其它springdata一致,findBy等等语法参考springdata)
public interface UserDao extends ElasticsearchRepository<User,Integer> {
    List<User> findByArticleInfId(Integer aid);
}
3:实体类
@Document(indexName = "article_inf_index", type = "articleInf")
@Setting(settingPath = "elasticsearch-analyser.json")
public class User implements Serializable {
//elasticsearch
@org.springframework.data.annotation.Id
private Integer articleInfId; @Field(type = FieldType.String)//使用ngram进行单字分词
private String articleTitle; @Field(type = FieldType.Date, store = true, format = DateFormat.custom, pattern ="yyyy-MM-dd HH:mm:ss")
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern ="yyyy-MM-dd HH:mm:ss")
private Date releaseTime; public Integer getArticleInfId() {
return articleInfId;
} public void setArticleInfId(Integer articleInfId) {
this.articleInfId = articleInfId;
} public String getArticleTitle() {
return articleTitle;
} public void setArticleTitle(String articleTitle) {
this.articleTitle = articleTitle;
} public Date getReleaseTime() {
return releaseTime;
} public void setReleaseTime(Date releaseTime) {
this.releaseTime = releaseTime;
} @Override
public String toString() {
return "User{" +
"articleInfId=" + articleInfId +
", articleTitle='" + articleTitle + '\'' +
", releaseTime=" + releaseTime +
'}';
}
} 4:serverce
@Service("testService")
public class ElasticsearchService {
    @Autowired
    private UserDao userDao;
    public void add(User user){
        userDao.save(user);
    }
    public List<User> search(Integer aid){
        Pageable pageable=new Pageable() {
            @Override
            public int getNumberOfPages() {
                return 0;
            }
            @Override
            public PageFormat getPageFormat(int pageIndex) throws IndexOutOfBoundsException {
                return null;
            }
            @Override
            public Printable getPrintable(int pageIndex) throws IndexOutOfBoundsException {
                return null;
            }
        };
        return this.userDao.findByArticleInfId(aid);
    }
public User searchByQuery(User user){
        BoolQueryBuilder qb= QueryBuilders. boolQuery();
        qb.must(QueryBuilders.matchQuery("articleInfId",12));
        Iterable<User> search = userDao.search(qb);
        return search.iterator().next();
    }
}
BoolQueryBuilder方法:
1.matchAllQuery() matchAllQuery()方法用来匹配全部文档
2.matchQuery("filedname","value")匹配单个字段,匹配字段名为filedname,值为value的文档
3.multiMatchQuery(Object text, String... fieldNames)多个字段匹配某一个值
QueryBuilder queryBuilder = QueryBuilders.multiMatchQuery("music", "name", "interest");//搜索name中或interest中包含有music的文档(必须与music一致)
4.wildcardQuery()模糊查询 ?匹配单个字符,*匹配多个字符
5.使用BoolQueryBuilder进行复合查询
使用must:
- //模糊查询
- WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(
- "name", "*jack*");//搜索名字中含有jack的文档
- WildcardQueryBuilder queryBuilder2 = QueryBuilders.wildcardQuery(
- "interest", "*read*");//搜索interest中含有read的文档
- BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
- //name中必须含有jack,interest中必须含有read,相当于and
- boolQueryBuilder.must(queryBuilder1);
- boolQueryBuilder.must(queryBuilder2);
使用 should:
- WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(
- "name", "*jack*");//搜索名字中含有jack的文档
- WildcardQueryBuilder queryBuilder2 = QueryBuilders.wildcardQuery(
- "interest", "*read*");//搜索interest中含有read的文档
- BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
- //name中含有jack或者interest含有read,相当于or
- boolQueryBuilder.should(queryBuilder1);
- boolQueryBuilder.should(queryBuilder2);
springdata -----操作ES的更多相关文章
- JPA + SpringData 操作数据库原来可以这么简单 ---- 深入了解 JPA - 1
		原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7703679.html ------------------------------------ ... 
- JPA + SpringData 操作数据库原来可以这么简单 ---- 深入了解 JPA - 2
		原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7704914.html ------------------------------------ ... 
- JPA + SpringData 操作数据库原来可以这么简单 ---- 深入了解 JPA - 3
		原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7718741.html ------------------------------------ ... 
- JPA + SpringData 操作数据库 ---- 深入了解 SpringData
		原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7735616.html ------------------------------------ ... 
- Elasticsearch笔记五之java操作es
		Java操作es集群步骤1:配置集群对象信息:2:创建客户端:3:查看集群信息 1:集群名称 默认集群名为elasticsearch,如果集群名称和指定的不一致则在使用节点资源时会报错. 2:嗅探功能 ... 
- SpringBoot整合SpringDataElasticSearch操作ES
		(1).添加starter依赖 <dependency> <groupId>org.springframework.boot</groupId> <artif ... 
- SpringBoot整合Jest操作ES
		(1).添加依赖 <dependency> <groupId>io.searchbox</groupId> <artifactId>jest</a ... 
- SpringBoot操作ES进行各种高级查询
		SpringBoot整合ES 创建SpringBoot项目,导入 ES 6.2.1 的 RestClient 依赖和 ES 依赖.在项目中直接引用 es-starter 的话会报容器初始化异常错误,导 ... 
- 07_Kibana界面操作ES
		Kibana界面的API操作ES 1.创建索引 1.1 指定分片数量和备份数量 1.2 创建默认 2. 查看索引 2.1 查看单个索引设置 2.2 查看所有索引设置 3.文档管理 3.1 添加文档 3 ... 
随机推荐
- Git操作行
			基础层:-----------------#初始化一个版本仓库git init #复制远程版本库git clone url #添加远程版本库origingit remote add origin ur ... 
- Angular2快速入门-4.创建一个服务(创建NewsService提供数据)
			上篇我们使用的数据是通过mock-news.ts中的const News[] 数组直接赋给Component 组件的,这篇我们把提供数据的部分单独封装成服务 第一.创建news.service.ts ... 
- poj2356 Find a multiple
			/* POJ-2356 Find a multiple ----抽屉原理 Find a multiple Time Limit: 1000MS Memory Limit: 65536K Total S ... 
- ubuntu 固定静态IP
			http://jingyan.baidu.com/article/e5c39bf5bbe0e739d7603396.html 路由器每重启一次,IP都会改变,那么实验室的路由器一天要断电好几次,那么每 ... 
- 11_java之接口和多态
			01接口的概念 * A:接口的概念 接口是功能的集合,同样可看做是一种数据类型,是比抽象类更为抽象的”类”. 接口只描述所应该具备的方法,并没有具体实现,具体的实现由接口的实现类(相当于接口的子类)来 ... 
- cento7.3下玩转sphinx
			cento7.5下玩转sphinx 1 安装依赖文件 yum install postgresql-libs unixODBC 2 下载 wget http://sphinxsearch.com/fi ... 
- split分隔
			split() : 把一个字符串分割成字符串数组 <script> var str="name=ww;value=ll"; var mm=str.split(" ... 
- Linux下安装php的memcached扩展(memcache的客户端)
			php的扩展memcache,不支持cas,所以我们要装memcached扩展,memcached扩展是基于libmemcached,所以要先安装libmemcached 一.下载软件 1.libme ... 
- Java静态代码块
			static{ //代码 } 在加载类的时候,会执行静态代码块-->非静态代码块--->构造函数 http://www.cnblogs.com/panjun-Donet/archive/2 ... 
- Ubuntu更新命令 <转>
			apt-cache search package 搜索包 apt-cache show package 获取包的相关信息,如说明.大小.版本等 sudo apt-get install package ... 
