#include #include #include "query/plan_interface.hpp" #include "storage/edge_accessor.hpp" #include "storage/vertex_accessor.hpp" #include "using.hpp" #include "query/parameters.hpp" using std::cout; using std::endl; // Query: CREATE (g:garment {garment_id: 1234, garment_category_id: // 1,reveals:30}) RETURN g class CPUPlan : public PlanInterface { public: bool run(GraphDbAccessor &db_accessor, const Parameters &args, Stream &stream) { auto v = db_accessor.insert_vertex(); v.add_label(db_accessor.label("garment")); v.PropsSet(db_accessor.property("garment_id"), args.At(0)); v.PropsSet(db_accessor.property("garment_category_id"), args.At(1)); v.PropsSet(db_accessor.property("reveals"), args.At(2)); std::vector headers{std::string("g")}; stream.Header(headers); std::vector result{TypedValue(v)}; stream.Result(result); std::map meta{std::make_pair(std::string("type"), TypedValue(std::string("rw")))}; stream.Summary(meta); db_accessor.commit(); return true; } ~CPUPlan() {} }; extern "C" PlanInterface *produce() { return new CPUPlan(); } extern "C" void destruct(PlanInterface *p) { delete p; }