下面是一个使用ArangoDB进行自连接查询的示例代码:
首先,我们需要创建一个包含一些数据的集合。在这个示例中,我们将创建一个名为"employees"的集合,包含以下字段:id,name和managerId。
// 创建employees集合
db._create("employees");
// 添加一些示例数据
db.employees.save({ "_key": "1", "name": "John", "managerId": null });
db.employees.save({ "_key": "2", "name": "Bob", "managerId": "1" });
db.employees.save({ "_key": "3", "name": "Alice", "managerId": "1" });
db.employees.save({ "_key": "4", "name": "Eve", "managerId": "3" });
接下来,我们可以使用AQL(ArangoDB查询语言)执行自连接查询。以下是一个示例查询,返回每个员工的名称和其直接上级的名称。
// 自连接查询
var aqlQuery = `
FOR e IN employees
LET manager = (
FOR m IN employees
FILTER m._key == e.managerId
RETURN m.name
)
RETURN { "Employee": e.name, "Manager": manager[0] }
`;
// 执行查询
var cursor = db._query(aqlQuery);
// 输出结果
while (cursor.hasNext()) {
var result = cursor.next();
print(result.Employee + " - " + result.Manager);
}
运行以上代码,将输出以下结果:
John - null
Bob - John
Alice - John
Eve - Alice
这个示例查询使用了两个FOR循环,第一个循环遍历所有员工,第二个循环在每次迭代中查找员工的上级。
注意:在实际使用中,您可能需要根据自己的数据模型和查询需求进行调整。