如何防止在OrientDB中创建相同顶点之间的边复制?

Xyl*_*ian 8 java sql graph orientdb

我有顶点"人物"和边缘"知道".这是我如何创建它的SQL示例.

CREATE CLASS Person EXTENDS V;
CREATE PROPERTY Person.name STRING;

CREATE CLASS Knows EXTENDS E;

INSERT INTO Person (name) VALUES("John")
INSERT INTO Person (name) VALUES("Ann")
INSERT INTO Person (name) VALUES("Harry")
Run Code Online (Sandbox Code Playgroud)

当我在约翰之间创造一个优势时 - > Ann by

CREATE EDGE Knows FROM (SELECT FROM Person WHERE name = "John") 
TO (SELECT FROM PERSON WHERE name = "Ann") 
Run Code Online (Sandbox Code Playgroud)

它创造了它,每件事都没问题.

但是当我意外地多次创建边缘时会出现问题.

对于关系"知道"重复是多余的,但对于其他一些如"访问"(John [Visited - >] New York),如果边缘"已访问"具有属性"日期",则边缘的重复是期望的特征.

我试图通过向边缘"Knows"添加唯一索引来解决它,但之后我只能在一对顶点之间创建边缘.

并且在创作之前检查每一次存在的边缘对我来说似乎也不是一个好主意.

如何以正确的方式解决这个问题?

Lui*_*ila 6

直接的解决方案是在EdgeClass [out,in]上创建索引。为此,您还必须为边缘类定义架构:

CREATE CLASS Knows EXTENDS E
CREATE PROPERTY Knows.out LINK Person
CREATE PROPERTY Knows.`in` LINK Person
CREATE INDEX Knows.out_in ON Knows (out, in) UNIQUE
Run Code Online (Sandbox Code Playgroud)