elasticsearch 操作
2024-08-27 00:36:00
文档:https://www.elastic.co/guide/en/elasticsearch/reference/current/index.html
客户端:https://www.elastic.co/guide/en/elasticsearch/client/index.html
API:https://www.elastic.co/guide/en/elasticsearch/reference/6.4/search-request-from-size.html
.net
1.连接,项目中引用Nest包
var settings = new ConnectionSettings(new Uri("http://example.com:9200"))
.DefaultIndex("people"); var client = new ElasticClient(settings);
2.索引
public class Person
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
}
var person = new Person
{
Id = ,
FirstName = "Martijn",
LastName = "Laarman"
}; var indexResponse = client.IndexDocument(person); var asyncIndexResponse = await client.IndexDocumentAsync(person);
3.查询
var searchResponse = client.Search<Person>(s => s
.From()
.Size()
.Query(q => q
.Match(m => m
.Field(f => f.FirstName)
.Query("Martijn")
)
)
); var people = searchResponse.Documents;
4.删除
var person = new Person
{
Id =
};
var deleteResponse= client.Delete<Person>(dept);
在kibana中操作
查看
删除
添加一个新的Index
public class StudentQuery
{
public int StudentId { get; set; }
public List<string> Items { get; set; }
}
var settings = new ConnectionSettings(new Uri("http://10.15.4.155:9200/")).DefaultIndex("student");
var client = new ElasticClient(settings);
for (int i = ; i < ; i++)
{
StudentQuery student = new StudentQuery();
student.StudentId = i;
student.Items = new List<string>();
student.Items.Add("Code"+i);
student.Items.Add("Name"+i);
student.Items.Add("CardId"+i);
student.Items.Add("IdentityId"+i);
var indexResponse = client.IndexDocument(student);
}
查询
var searchResponse = client.Search<StudentQuery>(s => s.
Query(q=>q.
Match(m=>m.
Field(f=>f.Items)
.Query("CardId1")
)
)
);
在kibana中查询
GET /student/studentquery/_search/
{
"query": {
"match": {
"items": {
"query": "Code8"
}
}
}
}
对同一字段多个值查询
或者使用term
GET /_search
{
"from" : 0, "size" : 10,
"query" : {
"term" : { "user" : "kimchy" }
}
}
这里要注意match和term的区别
Why doesn’t the term
query match my document?
简单来说就是string类型的字段在index之前会已fulltext的方式被es进行默认分词,比如放入“基金交易”,用term来查“基金”可能就查不到,用match就可以。
Java
@Service
public class ElasticService {
@Value("${elastic.host}")
private String host;
@Value("${elastic.port}")
private int port; private RestHighLevelClient client; public void index(String index, List<MetisQuestion> list) throws Exception {
client = new RestHighLevelClient(
RestClient.builder(
new HttpHost(host, port, "http")));
for(MetisQuestion o :list){
IndexRequest request = new IndexRequest(index,"doc");
ObjectMapper mapper=new ObjectMapper();
String json=mapper.writeValueAsString(o);
request.source(json, XContentType.JSON);
IndexResponse response = client.index(request, RequestOptions.DEFAULT);
System.out.println(response.status());
}
} public void search(String index,String key){
client = new RestHighLevelClient(
RestClient.builder(
new HttpHost(host, port, "http")));
SearchRequest searchRequest = new SearchRequest(index);
searchRequest.types("doc");
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.query(QueryBuilders.termQuery("question", key));
searchRequest.source(sourceBuilder);
getResponse(searchRequest);
} public void search(String index,String key,String... values){
client = new RestHighLevelClient(
RestClient.builder(
new HttpHost(host, port, "http")));
SearchRequest searchRequest = new SearchRequest(index);
searchRequest.types("doc");
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.query(QueryBuilders.termsQuery(key,values));
sourceBuilder.size(5);
searchRequest.source(sourceBuilder);
getResponse(searchRequest);
} private void getResponse(SearchRequest searchRequest) {
try {
SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
SearchHits hits = searchResponse.getHits();
for (SearchHit hit : hits) {
String sourceAsString = hit.getSourceAsString();
ObjectMapper mapper=new ObjectMapper();
MetisQuestion question=mapper.readValue(sourceAsString,MetisQuestion.class);
System.out.println(question.getQuestion());
}
} catch (IOException e) {
e.printStackTrace();
}
} }
最新文章
- 在Web Api中集成protobuf
- Python函数参数学习笔记
- java练手 公约数和公倍数
- NULL-safe equal
- POJ 3041 匈牙利算法模板题
- JAVA开发-我的第一个webScan扫描器
- Java-输入输出
- JAVA 对象数组,加载图片实例 分类: Java Game 2014-08-14 16:57 80人阅读 评论(0) 收藏
- 重新安装python
- WPF扩展标记
- Android应用程序之间共享文字和图片(一)
- 事关Animation Tree的工作随笔(一)
- 向eclipse的JavaWeb项目中导入jar包--备忘录
- oracle数据库知识点
- intellij idea svn使用一 导入、更新、提交、解决冲突
- Charles 抓包工具使用部分问题总结
- vc图像合成
- 【C#】【对象转XML】xml序列化
- 删除单链表节点,时间复杂度为O(1)
- postgresql 最大连接数相关
热门文章
- 虚方法(virtual)和抽象方法(abstract)的和接口(interface)的区别
- Web3D
- 2019.03.29 bzoj3323: [Scoi2013]多项式的运算(非旋treap)
- tp5 数据库
- (23)The surprising connection between brain injuries and crime
- 添加sqljdbc的maven依赖JAVA环境配置
- java中的接口与继承,接口的例子讲解
- CDR锁定方式
- 对list遍历删除符合的数据
- 使用java开发spark的wordcount程序(多种实现)