我有一个用户域,其中:1)String username,2)String password,3)Roles [] roles(Roles is enum)。
我的UserRepository中的方法如下:
@Query("MERGE (n:User:_User { username: \"{0}.username\", password: \"{0}.password\", roles: \"{0}.roles\" }) RETURN n")
User registerUser(User user);
抛出org.springframework.core.convert.ConversionFailedException
,因为它无法将String转换为角色,这是一个枚举。如果我摆脱{0} .roles附近的引号,那么它会抛出这个:
org.springframework.web.util.NestedServletException: Handler processing failed; nested exception is org.neo4j.helpers.ThisShouldNotHappenError: Developer: Andres claims that: Need something with properties
如果可以将User参数直接序列化为MERGE查询或以任何方式解析此Roles [],那将是理想的。
有人可以帮我吗?我使用的是SDN 3.1.0和Neo4J 2.0.3。
Update1:理想情况下,执行以下操作会非常棒:
@Query("MERGE (n:User:_User {0}) RETURN n")
User registerUser(User user);
答案 0 :(得分:1)
我不确定如何支持它。它必须将User转换为用作参数的映射,通常当您传入实体时,它将转换为该实体的内部node-id。
为什么不做template.save(user)
?
您可以尝试单独传递参数。
@Query("MERGE (n:User:_User { username: {0}, password: {1}, roles: {2} }) RETURN n")
User registerUser(String name, String password, Collection<String> roles);
答案 1 :(得分:0)
这实际上对我有用。
传递参数引用名称而不是传递参数位置。
@Query("MERGE (n:User:_User { username: {name}, password: {password}, roles: {roles} }) RETURN n")
User registerUser(String name, String password, Collection<String> roles);