8220808f56
Summary: Add vertex stream operator. Implement #0, #1 query. Support first batch of queries for testDB. Improve record stream handler. Query engine now supports multiline queries patterns in file comments. Second and third batch of tests complete. Add functionality to print_record_stream. Include 4th batch. Crete a shared function for properties output. Reviewers: buda Reviewed By: buda Subscribers: pullbot Differential Revision: https://phabricator.memgraph.io/D60
57 lines
1.8 KiB
C++
57 lines
1.8 KiB
C++
#include <iostream>
|
|
#include <string>
|
|
|
|
#include "query/plan_interface.hpp"
|
|
#include "storage/edge_accessor.hpp"
|
|
#include "storage/vertex_accessor.hpp"
|
|
#include "using.hpp"
|
|
|
|
using std::cout;
|
|
using std::endl;
|
|
|
|
// Query: MATCH (g1:garment {garment_id: 1234}), (g2:garment {garment_id: 4567})
|
|
// CREATE (g1)-[r:default_outfit]->(g2) RETURN r
|
|
|
|
class CPUPlan : public PlanInterface<Stream> {
|
|
public:
|
|
bool run(GraphDbAccessor &db_accessor, const TypedValueStore<> &args,
|
|
Stream &stream) {
|
|
stream.write_field("r");
|
|
std::vector<VertexAccessor> g1_set, g2_set;
|
|
for (auto g1 : db_accessor.vertices()) {
|
|
if (g1.has_label(db_accessor.label("garment"))) {
|
|
auto prop = g1.PropsAt(db_accessor.property("garment_id"));
|
|
if (prop.type_ == TypedValue::Type::Null) continue;
|
|
auto cmp = prop == args.at(0);
|
|
if (cmp.type_ != TypedValue::Type::Bool) continue;
|
|
if (cmp.Value<bool>() != true) continue;
|
|
g1_set.push_back(g1);
|
|
}
|
|
}
|
|
for (auto g2 : db_accessor.vertices()) {
|
|
if (g2.has_label(db_accessor.label("garment"))) {
|
|
auto prop = g2.PropsAt(db_accessor.property("garment_id"));
|
|
if (prop.type_ == TypedValue::Type::Null) continue;
|
|
auto cmp = prop == args.at(1);
|
|
if (cmp.type_ != TypedValue::Type::Bool) continue;
|
|
if (cmp.Value<bool>() != true) continue;
|
|
g2_set.push_back(g2);
|
|
}
|
|
}
|
|
for (auto g1 : g1_set)
|
|
for (auto g2 : g2_set) {
|
|
EdgeAccessor e = db_accessor.insert_edge(
|
|
g1, g2, db_accessor.edge_type("default_outfit"));
|
|
stream.write_edge_record(e);
|
|
}
|
|
stream.write_meta("rw");
|
|
return db_accessor.transaction_.commit();
|
|
}
|
|
|
|
~CPUPlan() {}
|
|
};
|
|
|
|
extern "C" PlanInterface<Stream> *produce() { return new CPUPlan(); }
|
|
|
|
extern "C" void destruct(PlanInterface<Stream> *p) { delete p; }
|