使用过程中遇到的问题记录
一、使用 $param 参数问题,如查询某些标签时不需要自动加双引号,如 match(n:label),而lable作为参数时,会自动加双引号变为 match(n:"label"), 这就会导致脚本出错,如代码中的参数 knowledgePointLabel 被加了双引号导致查询错误
import org.springframework.data.neo4j.repository.Neo4jRepository;
import org.springframework.data.neo4j.repository.query.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
/**
* 知识词条 持久层
*
* @author kou
*/
@Repository
public interface KnowledgeEntryRepository extends Neo4jRepository<KnowledgeEntry, Long> {
/**
* 统计文献关联的知识词条下的知识点数量
* (文献)-[r:`知识词条`]->(知识点)
*
* @param literatureId 文献id
* @param knowledgePointLabel 知识点label
* @return 结果
*/
@Query("MATCH(n:`文献`) " +
"where id(n) = $literatureId " +
"with n " +
"match (n)-[r:`知识词条`]-(k:`$knowledgePointLabel`) " +
"return count(k) ")
int countLiteratureKnowledgePoints(@Param("literatureId") Long literatureId, @

本文记录了在使用Neo4jRepository时,如何避免$param参数自动添加双引号导致的查询错误,提供了使用Cypher脚本拼接和Neo4jClient处理参数的方法。
最低0.47元/天 解锁文章
3274

被折叠的 条评论
为什么被折叠?



