ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Neo4j与Spring-最佳存储库设计

2019-11-11 07:20:56  阅读:275  来源: 互联网

标签:spring-boot neo4j spring-data-neo4j spring spring-repositories


目前,我正在基于Spring数据Neo4j进行项目.在大多数节点中,可能存在多种类型的不同关系,如下面的示例所示.

节点定义

    @NodeEntity(label = CollectionNames.User)
    public class User{

        @GraphId
        private Long id;

        //Different Parameters, removed because these are irrelevant
        @Relationship(type = RelationshipNames.HAS_CONTACT, direction = Relationship.OUTGOING)
        private Set<HasContact> contactList;

        @Relationship(type = RelationshipNames.HAS_INVITED, direction = Relationship.OUTGOING)
        private Set<HasInvited> invitedContacts;

        @Relationship(type = RelationshipNames.HAS_FAVORITE, direction = Relationship.OUTGOING)
        private Set<HasFavorite> favoriteMerchants;

    //And so many others such relationships

    //Constructor and Getters() & Setters()
}

储存库定义

@Repository
public interface UserRepository extends GraphRepository<User>{

    List<User> findByUsernameIn(Set<String> username, @Depth int depth);//Here for exp, I just want to load user with his/her 'contactList' entries only
    User findByUsername(String username, @Depth int depth);
}

尽管此存储库在以给定深度加载给定用户时可以正常工作,但是主要问题是此查询将以给定深度加载所有现有关系.正如我在这里只对某种/或一种特定类型的关系感兴趣,那么使用Spring Named Query方法怎么可能呢?使用命名查询方法加载时,可以为每个关系指定深度吗?还是我必须使用@Query注释为每个此类关系编写自定义查询?我们希望最大程度地减少自定义查询的使用!

那么,对于这种情况,Spring Data Neo4j中最好的存储库设计是什么?
建议将不胜感激!

解决方法:

从SDN版本4.2.x开始,@ Query中的自定义密码查询或使用session.query是避免加载所有相关实体的最佳选择.

在即将发布的版本中,将进行更细粒度的加载.看到这个github issue.

标签:spring-boot,neo4j,spring-data-neo4j,spring,spring-repositories
来源: https://codeday.me/bug/20191111/2018224.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有