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。