ElasticSearch操作Demo

package com.feng.elasticsearch;

import java.util.Date;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;

import org.elasticsearch.action.delete.DeleteResponse;
import org.elasticsearch.action.get.GetResponse;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.search.SearchType;
import org.elasticsearch.client.Client;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.elasticsearch.common.unit.TimeValue;
import org.elasticsearch.index.query.QueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.SearchHit;

public class ElasticSearchUtil {

	private Client client;

	public ElasticSearchUtil() {
		client = new TransportClient().addTransportAddress(new InetSocketTransportAddress("localhost", 9300));
	}

	public static void main(String[] args) {
		ElasticSearchUtil test = new ElasticSearchUtil();
		test.generateIndex();
		// test.getIndex();
		test.searchIndex();
		// test.deleteIndex();
		test.closeClient();
	}

	/**
	 * 创建索引
	 */
	public void generateIndex() {
		Map<String, Object> json = new HashMap<String, Object>();
		json.put("user", "sf");
		json.put("postDate", new Date());
		json.put("message", "trying out Elastic Search");

		IndexResponse response = client.prepareIndex("feng", "test", "1").setSource(json).execute().actionGet();
	}

	/**
	 * 查询索引
	 */
	public void getIndex() {
		GetResponse response = client.prepareGet("feng", "test", "1").execute().actionGet();
		Map<String, Object> rpMap = response.getSource();
		if (rpMap == null) {
			System.out.println("empty");
			return;
		}
		Iterator<Entry<String, Object>> rpItor = rpMap.entrySet().iterator();
		while (rpItor.hasNext()) {
			Entry<String, Object> rpEnt = rpItor.next();
			System.out.println(rpEnt.getKey() + " : " + rpEnt.getValue());
		}
	}

	/**
	 * 查询记录
	 */
	public void searchIndex() {

		QueryBuilder qb = QueryBuilders.termQuery("user", "sf");
		// 100|hits|per|shard|will|be|returned|for|each|scroll
		SearchResponse scrollResp = client.prepareSearch("feng")
											.setTypes("test")
											.setSearchType(SearchType.SCAN)
											.setScroll(new TimeValue(60000))
											.setQuery(qb)
											.setSize(100)
											.execute()
											.actionGet();
		// Scroll until no hits are returned
		while (true) {
			scrollResp = client.prepareSearchScroll(scrollResp.getScrollId()).setScroll(new TimeValue(600000)).execute()
					.actionGet();
			for (SearchHit hit : scrollResp.getHits()) {
				Iterator<Entry<String, Object>> rpItor = hit.getSource().entrySet().iterator();
				while (rpItor.hasNext()) {
					Entry<String, Object> rpEnt = rpItor.next();
					System.out.println(rpEnt.getKey() + " : " + rpEnt.getValue());
				}
			}
			// Break condition: No hits are returned
			if (scrollResp.getHits().hits().length == 0) {
				break;
			}
		}
	}

	public void deleteIndex() {
		DeleteResponse response = client.prepareDelete("feng", "test", "1").execute().actionGet();
	}

	public void closeClient() {
		client.close();
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
<?xml version="1.0" encoding="UTF-8"?> <project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>name.quanke</groupId> <artifactId>elasticsearch-java-study</artifactId> <version>1.0-SNAPSHOT</version> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> <properties> <elasticsearch.version>5.6.0</elasticsearch.version> <spring-version>5.0.0.RC3</spring-version> <fastjson-version>1.2.7</fastjson-version> <junit-version>4.12</junit-version> <slf4j-version>1.7.5</slf4j-version> <ik.version>5.5.1</ik.version> <spring-test-version>4.1.6.RELEASE</spring-test-version> <httpclient-version>4.5.1</httpclient-version> <zkclient-version>0.1</zkclient-version> <sl4j.version>1.7.25</sl4j.version> </properties> <dependencies> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>${fastjson-version}</version> </dependency> <dependency> <groupId>org.elasticsearch</groupId> <artifactId>elasticsearch</artifactId> <version>${elasticsearch.version}</version> </dependency> <dependency> <groupId>org.elasticsearch.client</groupId> <artifactId>transport</artifactId> <version>${elasticsearch.version}</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>${junit-version}</version> </dependency> <!--<dependency>--> <!--<groupId>org.elasticsearch</groupId>--> <!--<artifactId>elasticsearch-analysis-ik</artifactId>--> <!--<version>${ik.version}</version>--> <!--</dependency>--> <dependency> <groupId>org.elasticsearch.client</groupId> <artifactId>elasticsearch-rest-high-level-client</artifactId> <version>${elasticsearch.version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>${sl4j.version}</version> </dependency> </dependencies> <!-- 如果使用x-pack-transport 一定需要设置仓库地址--> <repositories> <repository> <id>spring-libs-snapshot</id> <name>Spring Snapshot Repository</name> <url>http://repo.spring.io/libs-snapshot</url> </repository> <repository> <id>elasticsearch-releases</id> <url>https://artifacts.elastic.co/maven</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories> </project>
好的,下面是一个简单的 Spring Boot 集成 Elasticsearch 的示例: 1. 首先,需要在 pom.xml 文件中添加 Elasticsearch 的依赖: ```xml <dependency> <groupId>org.elasticsearch.client</groupId> <artifactId>elasticsearch-rest-high-level-client</artifactId> <version>7.10.2</version> </dependency> ``` 2. 然后,在 application.yml 或 application.properties 中配置 Elasticsearch 的地址和端口: ```yaml spring: data: elasticsearch: cluster-name: elasticsearch cluster-nodes: localhost:9200 ``` 3. 创建一个实体类,用于映射 Elasticsearch 中的数据: ```java @Data @NoArgsConstructor @AllArgsConstructor @Builder @Document(indexName = "user", shards = 1, replicas = 0) public class User { @Id private String id; private String name; private Integer age; } ``` 4. 创建一个 Elasticsearch操作类,用于增删改查: ```java @Component public class ElasticsearchOperations { private final ElasticsearchRestTemplate elasticsearchRestTemplate; public ElasticsearchOperations(ElasticsearchRestTemplate elasticsearchRestTemplate) { this.elasticsearchRestTemplate = elasticsearchRestTemplate; } public void save(User user) { IndexQuery indexQuery = new IndexQueryBuilder() .withIndexName("user") .withObject(user) .build(); elasticsearchRestTemplate.index(indexQuery); } public void delete(String id) { elasticsearchRestTemplate.delete("user", id); } public void update(User user) { IndexRequest indexRequest = new IndexRequest("user") .id(user.getId()) .source(new ObjectMapper().convertValue(user, Map.class)); UpdateRequest updateRequest = new UpdateRequest("user", user.getId()) .doc(new ObjectMapper().convertValue(user, Map.class)) .upsert(indexRequest); elasticsearchRestTemplate.update(updateRequest); } public List<User> search(String keyword) { NativeSearchQuery searchQuery = new NativeSearchQueryBuilder() .withQuery(QueryBuilders.matchQuery("name", keyword)) .build(); return elasticsearchRestTemplate.queryForList(searchQuery, User.class); } } ``` 5. 最后,在 Controller 中使用 ElasticsearchOperations 进行增删改查操作: ```java @RestController @RequestMapping("/users") public class UserController { @Autowired private ElasticsearchOperations elasticsearchOperations; @PostMapping public void save(@RequestBody User user) { elasticsearchOperations.save(user); } @DeleteMapping("/{id}") public void delete(@PathVariable String id) { elasticsearchOperations.delete(id); } @PutMapping public void update(@RequestBody User user) { elasticsearchOperations.update(user); } @GetMapping public List<User> search(@RequestParam String keyword) { return elasticsearchOperations.search(keyword); } } ``` 以上就是一个简单的 Spring Boot 集成 Elasticsearch 的示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值