TigerGraph REST++API
简介 - 什么是REST ++?
TigerGraph TM 系统使用着名的REpresentational State Transfer(REST)架构来管理与TigerGraph核心组件,图形处理引擎(GPE)和图形存储引擎(GSE)的通信。REST ++(或RESTPP)是TigerGraph定制的REST服务器。(请参见下面的图1)当上层组件(如Platform Web UI或GSQL)希望访问图形引擎时,它会向REST ++服务器发送请求。用户还可以通过使用系统附带的标准REST API之一,或通过创作然后使用自定义终端API,直接与REST ++服务器通信。本文档描述了内置端点的API,该API提供了对图形数据进行基本查询和操作的方法。

图1 :TigerGraph系统框图
像大多数RESTful系统一样,REST ++采用HTTP协议(特别是没有请求流水线的HTTP / 1.1)。因此,REST API具有请求方法和URL,响应状态代码和数据响应。本指南介绍了用于查询,更新和从图数据中删除的请求方法和URL。它还描述了数据响应的格式。
TigerGraph REST API使用三种HTTP请求方法:
GET 用于请求数据。
POST 用于发送数据。
DELETE 用于删除数据。
如果用户提交不支持的HTTP方法,API将返回一条错误消息:“未找到端点”。
REST Request Format
To list only the first three vertices, we can set limit = 3:
Input Data for POST
Input data for POST requests should be in JSON format. There are two ways to supply the data: inline or in a separate file.
Inline Data
The data should be formatted as a single string without linebreaks. Use the curl - d option, followed by the JSON string.
The following example uses the POST /graph endpoint to insert one User type vertex whose id value is "id6" into the graph called "socialNet".
Data File
Often it will be more convenient for the input data to be in a separate file, especially if it is large.
Use the curl option --data-binary @path_to_file as in the example below:
If we now store the data string in a file (say, my_input.json), then the example above becomes the following:
REST++ Output
To make the output more human readable, use the jq command or Python json library built into most Linux installations. Specifically,
Example:
without postprocess formatting returns the following:
On the other hand,
returns this much more readable output:
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"v_id": "id2",
"v_type": "User",
"attributes": {}
},
{
"v_id": "id14",
"v_type": "User",
"attributes": {}
},
{
"v_id": "id58",
"v_type": "User",
"attributes": {}
}
]
}
GET /echo and POST /echo
These endpoints are simple diagnostic utilities which respond with the following message.
POST /echo has the same response as GET /echo.
GET /endpoints
This endpoint returns a list of the installed endpoints and their parameters. There are three types of endpoints, described in the table below.
|
Type |
Description |
|---|---|
|
builtin |
preinstalled in the TigerGraph system |
|
dynamic |
generated when compiling GSQL queries |
|
static |
user-installed endpoints |
GET /graph/graph_name/vertices
This endpoint returns all vertices having the type vertex_type in the graph called graph_name . Optionally, the user can instead chose a particular vertex by including its primary_id at the vertex_id field . For example:
graph_name: 图分组名称
vertex_type: 点的类型名称。目前demo:User Page Product DescWord NameUser VidUser Video AttributeTag Person SocialUser
vertex_id: 点的ID类型
curl -X GET "http://172.16.0.222:9000/graph/vertices/User/id1" | jq .
{ "version": { "api": "v2", "schema": 0 }, "error": false, "message": "", "results": [ { "v_id": "id1", "v_type": "User", "attributes": {} } ] }
count_only: BOOL(1/0/true/false)
curl -X GET 'http://172.16.0.222:9000/graph/vertices/SocialUser?count_only=1' | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"v_type": "SocialUser",
"count": 10
}
]
}
filter: 过滤attributes的属性
curl -X GET 'http://172.16.0.222:9000/graph/vertices/SocialUser?filter=name="peter"' | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"v_id": "6",
"v_type": "SocialUser",
"attributes": {
"name": "peter",
"isActive": true,
"registration_timestamp": 146000000
}
}
]
}
limit:限制放回个数
curl -X GET 'http://172.16.0.222:9000/graph/vertices/SocialUser?limit=2' | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"v_id": "6",
"v_type": "SocialUser",
"attributes": {
"name": "peter",
"isActive": true,
"registration_timestamp": 146000000
}
},
{
"v_id": "5",
"v_type": "SocialUser",
"attributes": {
"name": "steven",
"isActive": false,
"registration_timestamp": 145000000
}
}
]
}
select: 返回筛选的attributes的属性
curl -X GET 'http://172.16.0.222:9000/graph/vertices/SocialUser?select=name' | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"v_id": "6",
"v_type": "SocialUser",
"attributes": {
"name": "peter"
}
},
{
"v_id": "5",
"v_type": "SocialUser",
"attributes": {
"name": "steven"
}
},
{
"v_id": "8",
"v_type": "SocialUser",
"attributes": {
"name": "joseph"
}
},
{
"v_id": "7",
"v_type": "SocialUser",
"attributes": {
"name": "james"
}
},
{
"v_id": "2",
"v_type": "SocialUser",
"attributes": {
"name": "matthew"
}
},
{
"v_id": "4",
"v_type": "SocialUser",
"attributes": {
"name": "paul"
}
},
{
"v_id": "9",
"v_type": "SocialUser",
"attributes": {
"name": "thomas"
}
},
{
"v_id": "1",
"v_type": "SocialUser",
"attributes": {
"name": "john"
}
},
{
"v_id": "0",
"v_type": "SocialUser",
"attributes": {
"name": "luke"
}
},
{
"v_id": "3",
"v_type": "SocialUser",
"attributes": {
"name": "mark"
}
}
]
}
sort: 通过筛选的attributes的属性进行排序
curl -X GET 'http://172.16.0.222:9000/graph/vertices/SocialUser?sort=name' | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"v_id": "7",
"v_type": "SocialUser",
"attributes": {
"name": "james",
"isActive": true,
"registration_timestamp": 147000000
}
},
{
"v_id": "1",
"v_type": "SocialUser",
"attributes": {
"name": "john",
"isActive": true,
"registration_timestamp": 1410000000
}
},
{
"v_id": "8",
"v_type": "SocialUser",
"attributes": {
"name": "joseph",
"isActive": true,
"registration_timestamp": 148000000
}
},
{
"v_id": "0",
"v_type": "SocialUser",
"attributes": {
"name": "luke",
"isActive": true,
"registration_timestamp": 1400000000
}
},
{
"v_id": "3",
"v_type": "SocialUser",
"attributes": {
"name": "mark",
"isActive": true,
"registration_timestamp": 143000000
}
},
{
"v_id": "2",
"v_type": "SocialUser",
"attributes": {
"name": "matthew",
"isActive": false,
"registration_timestamp": 1420000000
}
},
{
"v_id": "4",
"v_type": "SocialUser",
"attributes": {
"name": "paul",
"isActive": true,
"registration_timestamp": 144000000
}
},
{
"v_id": "6",
"v_type": "SocialUser",
"attributes": {
"name": "peter",
"isActive": true,
"registration_timestamp": 146000000
}
},
{
"v_id": "5",
"v_type": "SocialUser",
"attributes": {
"name": "steven",
"isActive": false,
"registration_timestamp": 145000000
}
},
{
"v_id": "9",
"v_type": "SocialUser",
"attributes": {
"name": "thomas",
"isActive": true,
"registration_timestamp": 149000000
}
}
]
}
GET /graph/graph_name/edges
This endpoint returns all edges which connect to a given vertex ID in the graph called graph_name . A source vertex ID must be given. The user may optionally specify the edge type, the target vertex type, and the target vertex ID. The URL format is as follows:
- edge_type - type name of the edges. Use "_" to permit any edge type. Omitting the edge_type field from the URL also permits any edge type. However, skipping edge_type also means that target_vertex_type and target_vertex_id must be skipped.
- target_vertex_type - type name of the target vertices.
- target_vertex_id - ID of the target vertex.
source_vertex_type: 源点,如VidUser
source_vertex_id: 源点ID,如 0
edge_type: 边的类型,如User_Video
target_vertex_type: 目标点,如 User
target_vertex_id: 目标点ID ,如Video
sort: 通过筛选的attributes的属性进行排序
curl -X GET 'http://172.16.0.222:9000/graph/edges/VidUser/0/User_Video/Video' | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"e_type": "User_Video",
"directed": false,
"from_id": "0",
"from_type": "VidUser",
"to_id": "2",
"to_type": "Video",
"attributes": {
"rating": 5.2,
"date_time": 0
}
},
{
"e_type": "User_Video",
"directed": false,
"from_id": "0",
"from_type": "VidUser",
"to_id": "0",
"to_type": "Video",
"attributes": {
"rating": 6.8,
"date_time": 0
}
},
{
"e_type": "User_Video",
"directed": false,
"from_id": "0",
"from_type": "VidUser",
"to_id": "3",
"to_type": "Video",
"attributes": {
"rating": 10,
"date_time": 0
}
}
]
}
count_only、limit、select、sort、timeout 跟/graph/vertices一样
/graph/graph_name/edges has two optional parameters "count_only" and "not_wildcard":
- count_only: If it is true, the results contains only the number of edges selected. The default value is false.
- not_wildcard: This determines how the edge type name "_" is interpreted. If false (which is the default), "_" means all edge types are included. If not_wildcard is true, "_" is interpreted literally to select only edges with edge type name equal to underscore.
DELETE /graph/vertices
graph_name: 图分组名称
vertex_type: 点的类型名称。目前demo:User Page Product DescWord NameUser VidUser Video AttributeTag Person SocialUser
vertex_id: 点的ID类型
This endpoint deletes the given vertex(vertices) in the graph called graph_name . The URL is exactly the same as GET /graph/graph_name/vertices. This endpoint has an additional parameter "permanent", whose default value is false. If "permanent" is true, the deleted vertex ids can never be inserted back, unless the graph is dropped or the graph store is cleared.
Example:
curl -X DELETE "http://172.16.0.222:9000/graph/vertices/User/id64" | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": {
"v_type": "User",
"deleted_vertices": 1
}
}
DELETE /graph/edges
source_vertex_type: 源点,如VidUser
source_vertex_id: 源点ID,如 0
edge_type: 边的类型,如User_Video
target_vertex_type: 目标点,如 User
target_vertex_id: 目标点ID ,如Video
sort: 通过筛选的attributes的属性进行排序
Example:
curl -X DELETE "http://172.16.0.222:9000/graph/edges/VidUser/0/User_Video/Video" | jq .
{
"version": {
"api": "v2",
"schema": 0
},
"error": false,
"message": "",
"results": [
{
"e_type": "User_Video",
"deleted_edges": 3
}
]
}
This endpoint deletes the given edge(s). The URL is exactly the same as GET /graph/edges.
Advanced Parameters for /graph/vertices and /graph/edges
The above four endpoints, GET /graph/graph_name/vertices, GET /graph/graph_name/edges, DELETE /graph/graph_name/vertices, and DELETE /graph/graph_name/edges, have optional URL parameters for further operations:
- Select: Specify which attributes to be returned (GET only).
- Filter: Apply a filter on the vertices or edges, based on their attribute values.
- Limit: Limit the total number of vertices or edges.
- Sort: Sort the data. (For DELETE, sort should be used with limit together.)
- Timeout: Timeout in seconds. If set to 0, use system wide endpoint timeout setting.
The parameter 'Limit' can reduce the search space and leads to quick response of queries. However if Limit and Sort are both provided, the query still needs to traverse all potential vertices/edges and it might lead to slow query response on large graph.
Select
By default the GET /graph/vertices and /graph/edges endpoints return all the attributes of the selected vertices or edges. The select parameter can be used to specify either the desired or the undesired attributes. The format is select=attribute_list, where attribute_list is a list of comma-separated attributes. Listing an attribute name means that this attribute should be included, while an attribute name preceded by a minus sign means that this attribute should be excluded. An underscore means all attributes.
http://server_ip:9000/graph/graph_name/vertices?select=attr1,attr2returns only attributesattr1andattr2http://server_ip:9000/graph/graph_name/vertices?select=-attr1,-attr 2returns all attributes except attributesattr1andattr2http://server_ip:9000/graph/graph_name/vertices?select=-_returns no attribute at all
It is illegal to specify both desired and undesired attributes in the same request.
Example Query: Return the date_time attribute of all product vertices on socialNet.
Filter
The filter parameter is a set of conditions analogous to the WHERE clause in industry-standard SQL language. The format is filter=filter_list, where filter_list is a list of comma-separated filters, and each filter is the concatenation of an attribute, an operator, and a value (with no white spaces separating the parts). The following six comparison operators are supported:
=equal to!=not equal to>greater than>=greater than or equal to>less than<=less than or equal to
Here is an example request: It returns all User vertices with age greater than or equal to 30.
curl -X GET "http://172.16.0.222:9000/graph/vertices/User?filter=age>=30"
{"version":{"api":"v2","schema":0},"error":false,"message":"","results":[{"v_id":"id2","v_type":"User","attributes":{}},{"v_id":"id14","v_type":"User","attributes":{}},{"v_id":"id58","v_type":"User","attributes":{}}]}
TigerGraph REST++API的更多相关文章
- 干货来袭-整套完整安全的API接口解决方案
在各种手机APP泛滥的现在,背后都有同样泛滥的API接口在支撑,其中鱼龙混杂,直接裸奔的WEB API大量存在,安全性令人堪优 在以前WEB API概念没有很普及的时候,都采用自已定义的接口和结构,对 ...
- 12306官方火车票Api接口
2017,现在已进入春运期间,真的是一票难求,深有体会.各种购票抢票软件应运而生,也有购买加速包提高抢票几率,可以理解为变相的黄牛.对于技术人员,虽然写一个抢票软件还是比较难的,但是还是简单看看123 ...
- 几个有趣的WEB设备API(二)
浏览器和设备之间还有很多有趣的接口, 1.屏幕朝向接口 浏览器有两种方法来监听屏幕朝向,看是横屏还是竖屏. (1)使用css媒体查询的方法 /* 竖屏 */ @media screen and (or ...
- html5 canvas常用api总结(三)--图像变换API
canvas的图像变换api,可以帮助我们更加方便的绘画出一些酷炫的效果,也可以用来制作动画.接下来将总结一下canvas的变换方法,文末有一个例子来更加深刻的了解和利用这几个api. 1.画布旋转a ...
- JavaScript 对数据处理的5个API
JavaScript对数据处理包括向上取整.向下取整.四舍五入.固定精度和固定长度5种方式,分别对应ceil,floor,round,toFixed,toPrecision等5个API,本文将对这5个 ...
- ES5对Array增强的9个API
为了更方便的对Array进行操作,ES5规范在Array的原型上新增了9个方法,分别是forEach.filter.map.reduce.reduceRight.some.every.indexOf ...
- javascript的api设计原则
前言 本篇博文来自一次公司内部的前端分享,从多个方面讨论了在设计接口时遵循的原则,总共包含了七个大块.系卤煮自己总结的一些经验和教训.本篇博文同时也参考了其他一些文章,相关地址会在后面贴出来.很难做到 ...
- 一百元的智能家居——Asp.Net Mvc Api+讯飞语音+Android+Arduino
大半夜的,先说些废话提提神 如今智能家居已经不再停留在概念阶段,高大上的科技公司都已经推出了自己的部分或全套的智能家居解决方案,不过就目前的现状而言,大多还停留在展厅阶段,还没有广泛的推广起来,有人说 ...
- 在一个空ASP.NET Web项目上创建一个ASP.NET Web API 2.0应用
由于ASP.NET Web API具有与ASP.NET MVC类似的编程方式,再加上目前市面上专门介绍ASP.NET Web API 的书籍少之又少(我们看到的相关内容往往是某本介绍ASP.NET M ...
随机推荐
- bzoj3136: [Baltic2013]brunhilda
这个题为什么会放在数据结构啊 首先因为有决策包容性,对于一个n每次必然选择一个n%p最大的p,令n减n%p 设fi表示i变成0的步数的话,同样我们可以知道f是有单调性的 假如fd能转移到fk,首先d一 ...
- hdu 1166 敌兵布阵 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 题目意思:给出 N 个数你,通过对某些数进行更改(或者 + 或者 -),当输入的是 Query ...
- 简单的JDBC封装
JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口 ...
- "Activity" 总结
1.什么是Activity? 1.四大组件之一 2.通常一个界面对应一个activity 3.是Context的子类 4.同时实现window.callback和keyevent.callback回调 ...
- C#面向对象之数据库(理论、插入、修改、删除、查询)
1.数据库的作用:不仅仅是存储,更重要的是将数据进行存储以后怎么样才能方便快捷的查询修改 2.数据库的特点:海量存储.查找速度快.并发性问题控制.安全性.数据完整性(保存在数据库中的数据是正确的.真是 ...
- sublime text 3中修改tab键为缩进4个空格
1. 菜单栏里点击 Preferences-> Setting-User, 如图 2. 在弹出来的文本里,添加如下两行: { // 注意只有一个大括号,如果之前有属性,如在之前的属性后确保有 , ...
- 如何升级xcode 中的cocos2dx 到v2.2.2以上版本
每次升级cocos2dx版本都觉得不知道怎么弄才行. 这次升级到v2.2.2版本又花了我不少时间.因此在这里分享一下,以后也有地方可以查询. 1. 到http://cocos2d-x.org/ 下载最 ...
- cclfow_小流程设计
官网演示地址:http://demo.ccflow.org/ 流程的主要需求: 新建流程 登陆系统后台进行设置流程:鼠标右键流程树 选择新建子级类别 输入子级类别名称:流程演示,点击确定即可 点击流程 ...
- 在Emacs下用C/C++编程(转载)
转自:http://www.caole.net/diary/emacs_write_cpp.html Table of Contents 版权说明和参考文献 参考文献: 版权说明: 序 基本流程 基本 ...
- web移动端下拉加载数据简单实现
//下拉加载在移动端会经常使用,有些小伙伴不清楚一些原理下面就简答的介绍一下 //首先需要监听window的滚动事件,下拉其实就是在监听window滚动事件 var pageNum = 1;//分页第 ...