2017-02-14 16:37:32 +08:00
|
|
|
#include <iostream>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "query/plan_interface.hpp"
|
2017-02-18 18:54:37 +08:00
|
|
|
#include "query/util.hpp"
|
2017-02-14 16:37:32 +08:00
|
|
|
#include "storage/edge_x_vertex.hpp"
|
2017-02-18 18:54:37 +08:00
|
|
|
#include "storage/model/properties/all.hpp"
|
2017-02-14 16:37:32 +08:00
|
|
|
#include "using.hpp"
|
|
|
|
|
|
|
|
using std::cout;
|
|
|
|
using std::endl;
|
|
|
|
|
|
|
|
// Query: MATCH (a {id:0}), (p {id: 1}) CREATE (a)-[r:IS]->(p) RETURN r
|
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
class CPUPlan : public PlanInterface<Stream> {
|
|
|
|
public:
|
|
|
|
bool run(Db &db, const PlanArgsT &args, Stream &stream) override {
|
|
|
|
DbAccessor t(db);
|
|
|
|
auto &edge_type = t.type_find_or_create("IS");
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
auto v1 = t.vertex_find(args[0].as<Int64>().value());
|
|
|
|
if (!option_fill(v1)) return t.commit(), false;
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
auto v2 = t.vertex_find(args[1].as<Int64>().value());
|
|
|
|
if (!option_fill(v2)) return t.commit(), false;
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
auto edge_accessor = t.edge_insert(v1.get(), v2.get());
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
edge_accessor.edge_type(edge_type);
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
stream.write_field("r");
|
|
|
|
stream.write_edge_record(edge_accessor);
|
|
|
|
stream.write_meta("w");
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
return t.commit();
|
|
|
|
}
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
~CPUPlan() {}
|
2017-02-14 16:37:32 +08:00
|
|
|
};
|
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
extern "C" PlanInterface<Stream> *produce() { return new CPUPlan(); }
|
2017-02-14 16:37:32 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
extern "C" void destruct(PlanInterface<Stream> *p) { delete p; }
|