ArangoDB查询语言AQL语法

1.查询类型

AQL查询必须返回一个结果(使用返回关键字return)或执行数据修改操作(通过使用关键字INSERT,UPDATE,REPLACE,REMOVE或UPSERT中的一个)。如果AQL解析器在同一个查询中检测到多个数据修改操作,或者它无法确定该查询是用于数据检索还是修改操作,则它将返回错误。AQL只允许一个查询字符串;因此分号来表示一个查询和独立的多个查询(如SQL)是不允许的。

2.空格

(空格、回车、换行和制表符设置)可用于查询文本,以增加其可读性。字符串中的空格或名称必须被引号括起来。

3.注释

注释可以嵌入在任何位置。注释中包含的文本将被AQL解析器忽略。多行注释不能嵌套。AQL支持两种类型的注释:单行注释:单斜杠注释单行,该行将被AQL解析器忽略。多行注释:以/*开始,以*/结束,多行注释可以跨越多行。

/* this is a comment */ RETURN 1

/* these */ RETURN /* are */ 1 /* multiple */ + /* comments */ 1

/* this is

a multi line

comment */

// a single line comment

4.关键字

AQL提供以下操作:

FOR:数组迭代

RETURN:结果预测

FILTER:结果过滤

SORT:结果排序

LIMIT:结果切片

LET:变量赋值

COLLECT:结果分组

INSERT:插入新文件

UPDATE:(部分)更新现有文件

REPLACE:替换现有文件

REMOVE:删除现有文件

UPSERT:插入或更新现有文件

AQL查询举例:

FOR u IN users

FILTER u.web== "hackcloud.cn" && u.active == true

RETURN u.name

在这个示例中根据web、active进行条件过滤,并返回user的name值。关键词是不区分大小写的。在这个文档中,所有关键字使用大写使他们有别于查询部分。目前关键字的完整列表:

AGGREGATE ALL AND ANY ASC COLLECT DESC

DISTINCT FALSE FILTER FOR GRAPH IN INBOUND

INSERT INTO LET LIMIT NONE NOT NULL OR

OUTBOUND REMOVE REPLACE RETURN SHORTEST_PATH

SORT TRUE UPDATE UPSERT WITH

Names(名称)

通常,Names用于标识AQL查询中的对象(集合,属性,变量和函数)。

任何Names的最大支持长度是64个字节。AQL中的Names始终区分大小写。关键字不得用作Names。如果要将保留关键字用作Names,则该Names必须包含反引号。一个例子是:

FOR f IN `filter`

RETURN f.`sort`

由于反引号,过滤和排序在这里解释为名称而不是关键字。

集合名称

集合名称可以按原样用于查询。如果集合恰好与关键字具有相同的名称,则该名称必须用反引号括起来。

请参阅ArangoDB中 有关收集命名约定的命名约定。

AQL目前在一个AQL查询中使用了多达256个集合的限制。此限制适用于所有涉及的文档和边缘集合的总和。

属性名称

引用集合中文档的属性时,必须使用完全限定的属性名称。这是因为在查询中可能会使用具有不明确属性名称的多个集合。为避免含糊不清,不允许引用不合格的属性名称。

有关属性命名约定的更多信息,请参阅ArangoDB中的命名约定。

FOR u IN users

FOR f IN friends

FILTER u.active == true && f.active == true && u.id == f.userId

RETURN u.name

在上例中,属性名称active,name,id和userId 使用它们所属的集合名称( 分别为u和f)进行限定。

变量名称

AQL允许用户将值分配给查询中的其他变量。所有分配了值的变量必须在查询的上下文中具有唯一的名称。变量名称必须与同一查询中使用的任何集合名称的名称不同。

FOR u IN users

LET friends = u.friends

RETURN { "name" : u.name, "friends" : friends }

在上面的查询中,用户是一个集合名称,而你和朋友都是变量名称。这是因为FOR和LET操作需要目标变量来存储它们的中间结果。

变量名称中的允许字符是字母a到z(大写和小写),数字0到9,下划线(_)符号和美元符号($)。变量名称不能以数字开头。如果变量名以下划线字符开头,则下划线后面必须至少有一个字母(az或AZ)或数字(0-9)。

美元符号只能用作变量名称中的第一个字符。

你可能感兴趣的:(database,ArangoDB,图数据库)