gpt4 book ai didi

c++ - C++ libneo4j_client 中的准备语句?

转载 作者:搜寻专家 更新时间:2023-10-31 02:14:13 25 4
gpt4 key购买 nike

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 是查询的参数。构建 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);

如果有多个参数,构建一个映射条目数组,例如:

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com