问题描述
据我所知,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 (将#修改为@)