c# - 使用 C# Datastax CassandraCSharpDriver.Graph 获取连接到已知顶点的所有未知顶点
问题描述
我正在尝试使用 C# Datastax CassandraCSharpDriver.Graph 代码获取通过边缘连接到已知顶点的所有未知顶点。
此 gremlin 代码正确返回未知顶点列表以及目标已知顶点:
g.V().has("mything","key", "mykey")
.emit()
.repeat(outE("contains").inV()).valueMap(true)
我在 C# 中尝试过这样的遍历,但它没有回来,我认为重复是无限的(或非常慢):
g.V()
.Has("mything", "key", "mykey")
.Emit()
.Repeat(g.V()
.Has("mything", "key", "mykey")
.OutE("contains").InV())
我在 C# 中尝试这样的遍历,但编译器不接受'("query")',所以我不确定如何将遍历放在 Repeat 子句中:
g.V()
.Has("mything", "key", "mykey")
.As("query").Emit()
.Repeat(("query").OutE("contains").InV())
重复子句的诀窍是什么?或者有没有更好的方法让所有未知顶点连接到 C# 中的已知顶点?
解决方案
我认为您正在寻找匿名图遍历类Gremlin.Net.Process.Traversal.__
:
var graphResultSet = await session.ExecuteGraphAsync(g.V()
.Has("mything", "key", "mykey").Emit()
.Repeat(__.OutE("contains").InV())).ConfigureAwait(false);
我用这个查询运行了一个简单的代码片段(如下所示),我得到了这个控制台输出:
[label: mything; key: mykey]
[label: mything1; key: mykey15]
[label: mything1; key: mykey12]
[label: mything; key: mykey]
[label: mything1; key: mykey17]
[label: mything1; key: mykey16]
[label: mything1; key: mykey14]
[label: mything1; key: mykey13]
[label: mything1; key: mykey1]
代码片段:
session.ExecuteGraph(new SimpleGraphStatement(
"schema.propertyKey('key').Text().ifNotExists().create();" +
"schema.edgeLabel('contains').multiple().ifNotExists().create();" +
"schema.vertexLabel('mything').properties('key').ifNotExists().create();" +
"schema.vertexLabel('mything1').properties('key').ifNotExists().create();" +
"schema.edgeLabel('contains').connection('mything', 'mything1').add();"));
var g = DseGraph.Traversal(session);
await session.ExecuteGraphAsync(g
.AddV("mything").Property("key", "mykey").As("cp")
.AddV("mything").Property("key", "mykey").As("cp1")
.AddV("mything1").Property("key", "mykey1").As("cl")
.AddV("mything1").Property("key", "mykey12").As("cl1")
.AddV("mything1").Property("key", "mykey13").As("cl2")
.AddV("mything1").Property("key", "mykey14").As("cl3")
.AddV("mything1").Property("key", "mykey15").As("cl4")
.AddV("mything1").Property("key", "mykey16").As("cl5")
.AddV("mything1").Property("key", "mykey17").As("cl6")
.AddE("contains").From("cp").To("cl")
.AddE("contains").From("cp1").To("cl1")
.AddE("contains").From("cp").To("cl2")
.AddE("contains").From("cp").To("cl3")
.AddE("contains").From("cp1").To("cl4")
.AddE("contains").From("cp").To("cl5")
.AddE("contains").From("cp").To("cl6"))
.ConfigureAwait(false);
var graphResultSet = await session.ExecuteGraphAsync(g.V()
.Has("mything", "key", "mykey").Emit()
.Repeat(__.OutE("contains").InV())).ConfigureAwait(false);
var vertices = graphResultSet.Select(elem => elem.To<Vertex>()).ToList();
Console.WriteLine(
string.Join(
Environment.NewLine,
vertices.Select(v => $"[label: {v.Label}; key: {v.GetProperty("key").Value}]")));
推荐阅读
- java - 如何在处理来自 Arduino 的数据时创建一个实时更新的表?
- python - 如何在python中用奇异点数值求解非线性ODE(BVP)?
- javascript - GKE 流量管理
- java - 求二叉树的高度
- swift - 快速计时器滞后
- shell - 如何将“请求文本”输入传递给“运行 Shell 脚本”
- maven - 将多个项目的工件和依赖项连接在一起
- powershell - 使用“0”参数调用“ExecuteQuery”的异常:“远程服务器返回错误:(401) 未经授权。”
- excel - For 循环将单元格从一张纸复制到另一张纸有效,但在循环结束时出错
- high-availability - Pacemaker 自定义资源代理在故障转移时不执行脚本