繁体   English   中英

在 Spring java 框架中使用 ElasticSearch 的最佳方式

[英]The Best way to use ElasticSearch in Spring java framework

我正在开发一个计划使用 elasticsearch 作为数据存储库的系统。 我正在尝试选择最佳方式来开发我的应用程序,该应用程序可以从 elasticsearch 索引和查询数据。 我拥有的系统是建立在 Spring 框架之上的。

使用Spring-data-elasticsearch ( https://github.com/spring-projects/spring-data-elasticsearch ) 是一个不错的选择吗?

还是使用elasticsearch 核心库本身是一个不错的选择?

我需要处理嵌套数据(内部对象),但 Spring-data-elasticsearch 最近似乎没有操作。

我希望我能找到问题的解决方案。 提前致谢。

Spring data elasticsearch 支持 elasticsearch 的大部分常见特性集,包括嵌套、内部对象和父子(最近)。

当你说要使用嵌套数据(内部对象)时,请清楚elasticsearch有两个概念:内部对象和嵌套对象。

详细解释可以在elasticsearch中的管理关系中找到

嵌套文档示例

个人实体:

@Document(indexName = "person" , type = "user")

public class Person {

    @Id
    private String id;

    private String name;

    @Field( type = FieldType.Nested)
    private List<Car> car;

    // setters-getters
}

汽车实体:

public class Car {
    private String name;
    private String model;
    //setters and getters 
}

设置数据:

Person foo = new Person();
foo.setName("Foo");
foo.setId("1");

List<Car> cars = new ArrayList<Car>();
Car subaru = new Car();
subaru.setName("Subaru");
subaru.setModel("Imprezza");
cars.add(subaru);
foo.setCar(cars);

索引:

IndexQuery indexQuery = new IndexQuery();
indexQuery.setId(foo.getId());
indexQuery.setObject(foo);

//creating mapping
elasticsearchTemplate.putMapping(Person.class);
//indexing document
elasticsearchTemplate.index(indexQuery);
//refresh
elasticsearchTemplate.refresh(Person.class, true);

搜索:

QueryBuilder builder = nestedQuery("car", boolQuery()
    .must(termQuery("car.name", "subaru"))
    .must(termQuery("car.model", "imprezza")));

SearchQuery searchQuery = new NativeSearchQueryBuilder().withQuery(builder).build();
List<Person> persons = elasticsearchTemplate.queryForList(searchQuery, Person.class);

您可以在嵌套对象测试中找到有关嵌套和内部对象的更多测试用例

您可以使用 IndexQuery 进行保存和更新:

public Serializable saveOrUpdate(Car car) {
    return template.index(new IndexQueryBuilder().withObject(car).build());
}

Spring data elasticsearch 使用传输客户端,AWS elasticsearch 不支持传输客户端。 AWS elasticsearch 仅支持 HTTP 客户端。 所以我认为elasticsearch最好的java客户端是JEST。 它还支持使用 IAM 的 AWS 身份验证。

同样对于使用 Spring Boot 在 Elasticsearch 中的类似查询,您可以进行如下操作:

Car car = new Car();
car.setName(new InnerField("name", "имя"));

QueryBuilder builder = QueryBuilders
            .boolQuery()
            .should(QueryBuilders.regexpQuery("name.ru", ".*" + name + ".*"))
            .should(QueryBuilders.regexpQuery("name.kk", ".*" + name + ".*"))
            .should(QueryBuilders.regexpQuery("name.qq", ".*" + name + ".*"));

NativeSearchQuery build = new NativeSearchQueryBuilder().withQuery(builder).build();

    elasticsearchOperations.queryForList(build, tClass);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM