ArangoDB是一个多模型数据库,支持文档、图形和键值数据模型。在ArangoDB中,你可以使用AQL(ArangoDB查询语言)来编写存储过程。以下是一个简单的ArangoDB存储过程的示例,该存储过程用于创建一个包含两个边属性的简单图形,并插入一些节点和边:
-- 定义存储过程名称
CREATE PROCEDURE createSimpleGraph()
BEGIN
-- 声明变量
DECLARE graphId VARCHAR(255);
-- 创建图形,如果已存在则忽略错误
CREATE GRAPH "SimpleGraph" IF NOT EXISTS {
-- 添加边集合,如果已存在则忽略错误
CREATE EDGE COLLECTION "edges" IF NOT EXISTS {
-- 设置边集合的属性
CREATE PROPERTIES "from" STRING,
"to" STRING;
};
-- 添加节点集合,如果已存在则忽略错误
CREATE VERTEX COLLECTION "nodes" IF NOT EXISTS {
-- 设置节点集合的属性
CREATE PROPERTIES "name" STRING;
};
};
-- 获取新创建的图形ID
SET graphId = CONCAT("graphs/", UUID());
-- 将图形ID插入到系统集合中
INSERT INTO _graphs (graph) VALUES { _key: graphId };
-- 返回创建的图形ID
RETURN graphId;
END;
要调用此存储过程,你可以使用以下AQL命令:
-- 调用存储过程
CALL createSimpleGraph();
这将创建一个名为"SimpleGraph"的图形,其中包含一个名为"edges"的边集合和一个名为"nodes"的节点集合。边集合具有"from"和"to"属性,节点集合具有"name"属性。最后,存储过程将返回创建的图形ID。