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

前端之家收集整理的这篇文章主要介绍了如何防止在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")

当我在约翰之间创造一个边缘 – >安
通过

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

猜你在找的Java相关文章