Spring Data Neo4j自定义查询列表参数不使用转换器

时间:2017-08-16 02:29:35

标签: spring-data-neo4j spring-data-neo4j-4 neo4j-ogm

NodeEntity:

@NodeEntity(label = "User")
public class UserNode {
    @GraphId
    private Long _gid;

    @Index(unique = true, primary = true)
    @Convert(ObjectIdConverter.class)
    private ObjectId id;
}

转换器:

public class ObjectIdConverter implements AttributeConverter<ObjectId, String>{
    @Override
    public String toGraphProperty(ObjectId value) {
        return ObjectIdUtils.compressed(value);
    }

    @Override
    public ObjectId toEntityAttribute(String value) {
        return ObjectIdUtils.uncompress(value);
    }
}

存储库:

public interface UserNodeRepository extends GraphRepository<UserNode> {
    @Query("MATCH (user:User) WHERE user.id IN {0} RETURN user")
    List<UserNode> findByIdIn(List<ObjectId> ids);
}

UserNodeRepository#findByIdIn是自定义查询。但请求参数直接转换为json 而不使用ObjectIdConverter。

日志:

o.n.o.drivers.bolt.request.BoltRequest   : Request: MATCH (user:User) WHERE user.id IN {0} RETURN user with params {0=[{timestamp=1500442853, machineIdentifier=11302907, processIdentifier=11906, counter=4709865, time=1500442853000, date=1500442853000, timeSecond=1500442853}, {timestamp=1500445335, machineIdentifier=11302907, processIdentifier=11906, counter=4709946, time=1500445335000, date=1500445335000, timeSecond=1500445335}, {timestamp=1500447522, machineIdentifier=11302907, processIdentifier=11906, counter=4710014, time=1500447522000, date=1500447522000, timeSecond=1500447522}, {timestamp=1500448399, machineIdentifier=11302907, processIdentifier=11906, counter=4710092, time=1500448399000, date=1500448399000, timeSecond=1500448399}]}

这是SDN的期望还是丢失了哪些概念?

1 个答案:

答案 0 :(得分:1)

对于自定义@Query的查找程序,这是不可能的。 OGM无法知道您的参数与具有@Convert注释的属性相关(根本不使用方法名称)。要解决此问题,请手动转换为您的属性类型,并将其用作参数:

@Query("MATCH (user:User) WHERE user.id IN {0} RETURN user")
List<UserNode> findByIdIn(List<String> ids);

然而,这适用于派生的查找程序 - OGM从方法名称知道该字段,并使用正确的转换器知道@Convert注释。

单个参数的示例:

List<UserNode> findById(ObjectId id);

不幸的是,IN运算符和集合参数似乎存在错误:

// doesn't work
List<UserNode> findByIdIn(List<ObjectId> ids);

我创建了a jira issue