Gremlin语言是图数据库最主流的查询语言,是Apache TinkerPop框架下规范的图语言,相当于SQL之于关系型数据库。为了图数据库使用者更好的掌握Gremlin这门图语言,我们对Gremlin Steps进行了分类与总结,接下来将会出一个Gremlin系列文章(分25期来完成这个计划),每一期会针对一类Step进行语法讲解与实例分析。
V()、E()、id()、label()、properties()、valueMap()、values()
V()、E()、id()、label()、properties()、valueMap()、values()
1、V():查询顶点,一般作为图查询的第1步,后面可以续接的语句种类繁多。
示例:
// 查询图中所有的顶点
// 注意:g 代表的是整个图
// 一切查询都是以图开始
g.V()
// 根据id查询顶点
g.V('vertex_id1', 'vertex_id2')
// 根查询支持Gremlin语言的所有图数据库。
g.V('id1').in('supports')
// 查询所有顶点的id
g.V().id()
2、E():查询边,一般作为图查询的第1步,后面可以续接的语句种类繁多。
示例:
// 查询图中所有的边
g.E()
// 查询所有边的id
g.E().id()
// 根据id查询边
g.E('edge_id1')
3、properties():获取顶点、边的属性
示例:
// 查询所有顶点的属性
g.V().properties()
// 查询所有顶点的“lang”属性
// 如果无“lang”属性的顶点将跳过
g.V().properties('lang')
// 查询所有边的属性
g.E().properties()
// 查询所有顶点的属性名称
g.V().properties().key()
// 查询所有顶点的属性值
g.V().properties().value()
4、valueMap():获取顶点、边的属性, valueMap()与 properties()不同的地方是:它们返回的结构不一样,后者将所有的属性扁平化到一个大列表里面,一个元素代表一个属性;前者保持一个顶点或一条边的属性作为一组,每一组由若干属性的键值对组成。
示例:
// 查询所有顶点的属性
g.V().valueMap()
//查询所有边的属性
g.E().valueMap()
// 查询所有顶点的属性值
// 效果等同于:
// g.V().properties().value()
g.V().values()
// 查询所有顶点的“lang”属性
// 效果等同于:
// g.V().properties('lang').value()
g.V().values('lang')
// 查询所有边的属性值
g.E().values()
深入学习Gremlin 系列文章链接汇总连接:https://blog.csdn.net/javeme/article/details/82631834s