带有neo4j jdbc驱动程序和neo4j 4的预准备语句中cypher查询中参数的语法是什么?

问题描述

据我所知,neo4j 4.x 现在不支持这种语法的参数 - {1},现在支持 $param。执行 PreparedStatement 的语法也发生了变化。我的意思是 - 当我尝试使用新的 jdbc 驱动程序 4.0.1 和 neo4j 4.2.3 执行查询时:

  String query = "MATCH (u:User)-[:FRIEND]-(f:User) WHERE u.name = {1} RETURN f.name,f.age";
    try (PreparedStatement stmt = con.prepareStatement(query)) {
        stmt.setString(1,"John");

        try (ResultSet rs = stmt.executeQuery()) {
            while (rs.next()) {
                System.out.println("Friend: "+rs.getString("f.name")+" is "+rs.getInt("f.age"));
            }
        }
    }

我收到此错误 - ParameterIndex 与 sql 语句中的参数标记不对应

因此,在使用较新版本的 neo4j 4.2.3 和 jdbc 驱动程序 4.0.1 的预准备语句查询中 {1} 的语法仍然有效还是需要进行任何更改?如果不是这样,那么您还可以建议这里可能是什么错误。 提前致谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)