如何防止在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

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...