Определение, если 2 вершины связаны с ребром, используя Orientdb 3 и tinkerpop 3 - PullRequest
0 голосов
/ 20 сентября 2018

Я пытался просмотреть документацию.Я просто пытаюсь найти простой пример, чтобы определить, как упомянуто в заголовке, если 2 вершины связаны друг с другом.Это для OrientDB 3, использующей чертежи API tinkerpop 2.6.Пример: вершина v1;Vertex v2;

boolean connected = false;

connected = <somefunction returns true/false if v1 and v2 connected by an edge>;

Может кто-нибудь привести пример, если он видел что-то подобное?

Ответы [ 2 ]

0 голосов
/ 28 сентября 2018

Вам нужно перебрать ребра одной вершины (v1) и проверить, соединяется ли она с другой вершиной (v2):

OrientVertex v1,v2; 
for (Edge e : (Iterable<Edge>)() ->  v1.edges(Direction.OUT)) 
    if (e.vertices(Direction.IN).next().id().equals(v2.id())) {
    }
0 голосов
/ 26 сентября 2018

попробуйте это:

String db_name = "dbname";
String path = "remote:localhost/" + db_name;

OrientDB orientDB = new OrientDB("remote:localhost", "username", "password", OrientDBConfig.defaultConfig());

try(ODatabaseSession db = orientDB.open(db_name,"username","password")) 
{
    ORID theEdge = new ORecordId("edge_rid");
    OEdge e = db.load(theEdge);

    ORID theVertex = new ORecordId("v1_rid");
    OVertex v1 = db.load(theVertex);

    ORID theVertex2 = new ORecordId("v2_rid");
    OVertex v2 = db.load(theVertex2);

    boolean connected = false;
    OVertex from = e.getFrom();
    OVertex to = e.getTo();

    if(from.getIdentity().equals(v1) && to.getIdentity().equals(v2))
    {
        connected = true;
    }

    if(connected)
    {
        System.out.println("Vertex v1: " + from.getIdentity());
        System.out.println("Vertex v2: " + to.getIdentity());
    }
}



Надеюсь, это поможет

С уважением

...