繁体   English   中英

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

[英]How to prevent creating duplicates of edges between the same vertices in 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")

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

CREATE EDGE Knows FROM (SELECT FROM Person WHERE name = "John") 
TO (SELECT FROM PERSON WHERE name = "Ann") 

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

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

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

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

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

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

直接的解决方案是在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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM