57f1b40d8d
Summary: Modification to MVCC - CHECK! Refactor transaction_read Add automatic commit/abort functionality to graph_db_accessor. Fix failing test in graph_db_accessor. Reviewers: buda, dtomicevic, florijan Reviewed By: buda, florijan Subscribers: pullbot Differential Revision: https://phabricator.memgraph.io/D87
46 lines
1.5 KiB
C++
46 lines
1.5 KiB
C++
#include <iostream>
|
|
#include <string>
|
|
|
|
#include "query/backend/cpp/typed_value.hpp"
|
|
#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 (p:profile {profile_id: 112, partner_id: 77}) RETURN p
|
|
|
|
class CPUPlan : public PlanInterface<Stream> {
|
|
public:
|
|
bool run(GraphDbAccessor &db_accessor, const PropertyValueStore<> &args,
|
|
Stream &stream) {
|
|
stream.write_field("p");
|
|
for (auto vertex : db_accessor.vertices()) {
|
|
if (vertex.has_label(db_accessor.label("profile"))) {
|
|
TypedValue prop = vertex.PropsAt(db_accessor.property("profile_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;
|
|
|
|
TypedValue prop2 = vertex.PropsAt(db_accessor.property("partner_id"));
|
|
if (prop2.type() == TypedValue::Type::Null) continue;
|
|
auto cmp2 = prop2 == args.at(1);
|
|
if (cmp2.type() != TypedValue::Type::Bool) continue;
|
|
if (cmp2.Value<bool>() != true) continue;
|
|
stream.write_vertex_record(vertex);
|
|
}
|
|
}
|
|
stream.write_meta("r");
|
|
db_accessor.commit();
|
|
return true;
|
|
}
|
|
~CPUPlan() {}
|
|
};
|
|
|
|
extern "C" PlanInterface<Stream> *produce() { return new CPUPlan(); }
|
|
|
|
extern "C" void destruct(PlanInterface<Stream> *p) { delete p; }
|