#pragma once #include "database/db.hpp" #include "query_engine/query_stripper.hpp" #include "query_engine/util.hpp" #include "storage/model/properties/property.hpp" #include "utils/command_line/arguments.hpp" auto load_queries(Db &db) { std::map> queries; // CREATE (n {prop: 0}) RETURN n) auto create_node = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto vertex_accessor = db.graph.vertices.insert(t); vertex_accessor.property("prop", args[0]); t.commit(); return true; }; queries[11597417457737499503u] = create_node; auto create_labeled_and_named_node = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto vertex_accessor = db.graph.vertices.insert(t); vertex_accessor.property("name", args[0]); auto &label = db.graph.label_store.find_or_create("LABEL"); vertex_accessor.add_label(label); cout_properties(vertex_accessor.properties()); t.commit(); return true; }; auto create_account = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto vertex_accessor = db.graph.vertices.insert(t); vertex_accessor.property("id", args[0]); vertex_accessor.property("name", args[1]); vertex_accessor.property("country", args[2]); vertex_accessor.property("created_at", args[3]); auto &label = db.graph.label_store.find_or_create("ACCOUNT"); vertex_accessor.add_label(label); cout_properties(vertex_accessor.properties()); t.commit(); return true; }; auto find_node_by_internal_id = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto id = static_cast(*args[0]); auto vertex_accessor = db.graph.vertices.find(t, Id(id.value)); if (!vertex_accessor) { cout << "vertex doesn't exist" << endl; t.commit(); return false; } cout_properties(vertex_accessor.properties()); cout << "LABELS:" << endl; for (auto label_ref : vertex_accessor.labels()) { cout << label_ref.get() << endl; } t.commit(); return true; }; auto create_edge = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto v1 = db.graph.vertices.find(t, args[0]->as().value); if (!v1) return t.commit(), false; auto v2 = db.graph.vertices.find(t, args[1]->as().value); if (!v2) return t.commit(), false; auto edge_accessor = db.graph.edges.insert(t, v1.vlist, v2.vlist); v1.vlist->update(t)->data.out.add(edge_accessor.vlist); v2.vlist->update(t)->data.in.add(edge_accessor.vlist); auto &edge_type = db.graph.edge_type_store.find_or_create("IS"); edge_accessor.edge_type(edge_type); t.commit(); cout << edge_accessor.edge_type() << endl; cout_properties(edge_accessor.properties()); return true; }; auto find_edge_by_internal_id = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto edge_accessor = db.graph.edges.find(t, args[0]->as().value); if (!edge_accessor) return t.commit(), false; // print edge type and properties cout << "EDGE_TYPE: " << edge_accessor.edge_type() << endl; auto from = edge_accessor.from(); cout << "FROM:" << endl; cout_properties(from->find(t)->data.props); auto to = edge_accessor.to(); cout << "TO:" << endl; cout_properties(to->find(t)->data.props); t.commit(); return true; }; auto update_node = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto v = db.graph.vertices.find(t, args[0]->as().value); if (!v) return t.commit(), false; v.property("name", args[1]); cout_properties(v.properties()); t.commit(); return true; }; // MATCH (n1), (n2) WHERE ID(n1)=0 AND ID(n2)=1 CREATE (n1)<-[r:IS {age: 25, // weight: 70}]-(n2) RETURN r auto create_edge_v2 = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto n1 = db.graph.vertices.find(t, args[0]->as().value); if (!n1) return t.commit(), false; auto n2 = db.graph.vertices.find(t, args[1]->as().value); if (!n2) return t.commit(), false; auto r = db.graph.edges.insert(t, n2.vlist, n1.vlist); r.property("age", args[2]); r.property("weight", args[3]); auto &IS = db.graph.edge_type_store.find_or_create("IS"); r.edge_type(IS); n2.vlist->update(t)->data.out.add(r.vlist); n1.vlist->update(t)->data.in.add(r.vlist); t.commit(); return true; }; queries[15648836733456301916u] = create_edge_v2; // MATCH (n) RETURN n auto match_all_nodes = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto vertices_accessor = db.graph.vertices.access(); for (auto &it : vertices_accessor) { auto vertex = it.second.find(t); if (vertex == nullptr) continue; cout_properties(vertex->data.props); } // TODO // db.graph.vertices.filter().all(t, handler); t.commit(); return true; }; queries[15284086425088081497u] = match_all_nodes; // MATCH (n:LABEL) RETURN n auto find_by_label = [&db](const properties_t &args) { auto &t = db.tx_engine.begin(); auto &label = db.graph.label_store.find_or_create("LABEL"); auto &index_record_collection = db.graph.vertices.find_label_index(label); auto accessor = index_record_collection.access(); cout << "VERTICES" << endl; for (auto &v : accessor) { cout << v.record->data.props.at("name").as().value << endl; } // TODO // db.graph.vertices.fileter("LABEL").all(t, handler); return true; }; queries[4857652843629217005u] = find_by_label; queries[10597108978382323595u] = create_account; queries[5397556489557792025u] = create_labeled_and_named_node; queries[7939106225150551899u] = create_edge; queries[6579425155585886196u] = create_edge; queries[11198568396549106428u] = find_node_by_internal_id; queries[8320600413058284114u] = find_edge_by_internal_id; queries[6813335159006269041u] = update_node; return queries; }