一:配置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:

  1. //模糊查询
  2. WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(
  3. "name", "*jack*");//搜索名字中含有jack的文档
  4. WildcardQueryBuilder queryBuilder2 = QueryBuilders.wildcardQuery(
  5. "interest", "*read*");//搜索interest中含有read的文档
  6. BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
  7. //name中必须含有jack,interest中必须含有read,相当于and
  8. boolQueryBuilder.must(queryBuilder1);
  9. boolQueryBuilder.must(queryBuilder2);

使用 should:

  1. WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(
  2. "name", "*jack*");//搜索名字中含有jack的文档
  3. WildcardQueryBuilder queryBuilder2 = QueryBuilders.wildcardQuery(
  4. "interest", "*read*");//搜索interest中含有read的文档
  5. BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
  6. //name中含有jack或者interest含有read,相当于or
  7. boolQueryBuilder.should(queryBuilder1);
  8. boolQueryBuilder.should(queryBuilder2);
												

springdata -----操作ES的更多相关文章

  1. JPA + SpringData 操作数据库原来可以这么简单 ---- 深入了解 JPA - 1

    原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7703679.html ------------------------------------ ...

  2. JPA + SpringData 操作数据库原来可以这么简单 ---- 深入了解 JPA - 2

    原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7704914.html ------------------------------------ ...

  3. JPA + SpringData 操作数据库原来可以这么简单 ---- 深入了解 JPA - 3

    原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7718741.html ------------------------------------ ...

  4. JPA + SpringData 操作数据库 ---- 深入了解 SpringData

    原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7735616.html ------------------------------------ ...

  5. Elasticsearch笔记五之java操作es

    Java操作es集群步骤1:配置集群对象信息:2:创建客户端:3:查看集群信息 1:集群名称 默认集群名为elasticsearch,如果集群名称和指定的不一致则在使用节点资源时会报错. 2:嗅探功能 ...

  6. SpringBoot整合SpringDataElasticSearch操作ES

    (1).添加starter依赖 <dependency> <groupId>org.springframework.boot</groupId> <artif ...

  7. SpringBoot整合Jest操作ES

    (1).添加依赖 <dependency> <groupId>io.searchbox</groupId> <artifactId>jest</a ...

  8. SpringBoot操作ES进行各种高级查询

    SpringBoot整合ES 创建SpringBoot项目,导入 ES 6.2.1 的 RestClient 依赖和 ES 依赖.在项目中直接引用 es-starter 的话会报容器初始化异常错误,导 ...

  9. 07_Kibana界面操作ES

    Kibana界面的API操作ES 1.创建索引 1.1 指定分片数量和备份数量 1.2 创建默认 2. 查看索引 2.1 查看单个索引设置 2.2 查看所有索引设置 3.文档管理 3.1 添加文档 3 ...

随机推荐

  1. java web 程序---在线时长

    思路:toLocalString()这个方法 <body> <% long t=session.getLastAccessedTime(); long t2=session.getC ...

  2. POJ 1222 EXTENDED LIGHTS OUT(反转)

    EXTENDED LIGHTS OUT Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 12616   Accepted: 8 ...

  3. Python GUI编程(Tkinter) windows界面开发

    Python实现GUI简单的来说可以调用Tkinter库,这样一般的需求都可以实现,显示简单的windows窗口代码如下: python_gui.py 1 #!C:\Python27\python.e ...

  4. UE4 代码总结

    1.创建关卡类 1.创建C++类继承LevelScriptActor 2.打开关卡蓝图 Class Settings->Parent Class 选择你之前创建好的C++类 遇到的问题: 1.T ...

  5. ALSA声卡10_从零编写之数据传输_学习笔记

    1.引言 (1)应用程序使用声卡的时候,数据流程是:应用程序把数据发送给驱动,驱动把数据发送给硬件声卡,声卡把数据转换成声音数据播放出去. (2)可以使用两种方式发送数据 第一种:app发数据,等驱动 ...

  6. CocoStudio创建动画帧

    进入动画编辑器 选择“形体模式” 右键点击资源窗口的资源,可以进行删除,重命名的操作:  可以再资源窗口下方的预览窗口,查看选中的资源预览效果图: 右键点击“对象结构”,创建图层 选择“动画模式” 右 ...

  7. jquery easy ui 的formatter 格式化函数代码

  8. linux find中的-print0和xargs中-0的奥妙

    默认情况下, find 每输出一个文件名, 后面都会接着输出一个换行符 ('n'), 因此我们看到的 find 的输出都是一行一行的: 比如我想把所有的 .log 文件删掉, 可以这样配合 xargs ...

  9. Android 4 学习(19):Services

    参考<Professional Android 4 Development> Services Service是invisible的,因此其优先级不高于visible的Activity,之 ...

  10. C# 在创建窗口句柄之前,不能在控件上调用 Invoke 或 BeginInvoke [问题点数:40分

    注意:  this.DateTimeRun = true;            new Thread(jishi_kernel).Start(); 线程的启动,不能放在    public Form ...