neo4j_run API允许您输入 map ,但是我不知道查询的语法。在python中,这是一个简单的{x}
。我找不到neo4j_map
语法的示例。
const char *q = "MATCH (p:Person) WHERE p.age > {age} RETURN p.name AS name, p.age as AGE";
neo4j_run(session, q, my_map)
我应该如何(a)构造
my_map
和(b)指示查询中的字段?更新:对于第一部分,this test显示了如何构造 map 。为了清晰起见,在此处复制:
START_TEST (invalid_map_value)
{
neo4j_map_entry_t map_entries[] =
{ { .key = neo4j_string("bernie"), .value = neo4j_int(1) },
{ .key = neo4j_int(1), .value = neo4j_int(2) } };
neo4j_value_t value = neo4j_map(map_entries, 2);
ck_assert(neo4j_is_null(value));
ck_assert_int_eq(errno, NEO4J_INVALID_MAP_KEY_TYPE);
}
END_TEST
最佳答案
作为第三个参数传递给neo4j_run
的映射是查询的参数。构造 map 需要一个条目数组及其长度。如果只是单个入口映射,则可以将指针传递给单个neo4j_map_entry_t
。例如:
const char *q = "MATCH (p:Person) WHERE p.age > {age} RETURN p.name AS name, p.age as AGE";
neo4j_map_entry_t map_entry = neo4j_map_entry("age", 28);
neo4j_value_t params = neo4j_map(&map_entry, 1);
neo4j_run(session, q, params);
如果有多个参数,则构建一个 map 条目数组,例如:
const char *q = "MATCH (p:Person) WHERE {min_age} < p.age < {max_age} RETURN p.name AS name, p.age as AGE";
neo4j_map_entry_t map_entries[2];
map_entries[0] = neo4j_map_entry("min_age", 28);
map_entries[1] = neo4j_map_entry("max_age", 30);
neo4j_value_t params = neo4j_map(map_entries, 2);
neo4j_run(session, q, params);
您还可以使用初始化程序来构建map_entry_t,如复制的示例测试中所示。但是使用
neo4j_map_entry
构造函数通常更清晰。关于c++ - 用C++编写的语句libneo4j_client?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40208873/