参数化查询背后的想法是重新使用(缓存)执行计划。
如果节点标签或关系类型不变,则执行计划将完全相同,因此可以受益于执行计划缓存。
当前,我是使用Java String Building构建的完整Cypher Query。而不是使用字符串构建来创建整个Cypher查询,我希望将属性的值作为参数值以及属性名称作为参数传递与否。我需要示例代码,同样的指导。
import org.neo4j.driver.v1.AuthTokens;
import org.neo4j.driver.v1.Driver;
import org.neo4j.driver.v1.GraphDatabase;
import org.neo4j.driver.v1.Session;
public class ForStackoverflowQuestion {
public static void main(String[] args) {
Driver driver = GraphDatabase.driver(
"bolt://localhost:7687", AuthTokens.basic("neo4j", "12345"));
Session session = driver.session();
String Node1 = "Software_Engineer";
String Node2 = "Programming_Language";
String relationBetweenNode1andNode2 = "LEARNS";
String PersonNameAttribute = "name";
String PersonNameValue = "Jaykant";
String ProgrammingLanguageAttribute = "version";
String ProgrammingLanguageValue = "Neo4j";
String t = "MERGE(n1:"+Node1+"{"+PersonNameAttribute+":\""+PersonNameValue+"\"})"+"-[:"+relationBetweenNode1andNode2+"]->(n2:" + Node2 +" {"+ProgrammingLanguageAttribute+":'"+ProgrammingLanguageValue+"'})";
System.out.println(t);
session.run(t);
session.close();
driver.close();
}
}
我了解我的上述代码未使用参数化密码查询;因此它将不会在neo4j中生成任何查询计划。
为了使用查询计划并从中受益,我需要使用参数化查询。
如果不是将Node1,Node2和RelationBetweenNode1和Node2作为参数,则至少可以将以下值作为参数传递。
PersonNameAttribute = "name";
PersonNameValue = "Jaykant";
ProgrammingLanguageAttribute = "version";
ProgrammingLanguageValue = "Neo4j";
有任何示例代码吗?教程?
答案 0 :(得分:1)
您可以在session.run()
方法中将参数与查询一起传递。
例如。
session.run(query, parameters)
参数应为地图。
HashMap<String, Object> parameters = new HashMap<String, Object>();
parameters.put("PersonNameValue", "Jaykant");
parameters.put("ProgrammingLanguageValue", "Neo4j");
查询可以修改为:
String t = "MERGE (n1:"+Node1+"{"+PersonNameAttribute+":{PersonNameValue}})"+"-[:"+relationBetweenNode1andNode2+"]->(n2:" + Node2 +" {"+ProgrammingLanguageAttribute+": {ProgrammingLanguageValue}})";
最后run
条语句:
session.run(t, parameters);