2016-07-02 05:05:03 +08:00
|
|
|
#include <iostream>
|
|
|
|
|
2016-07-07 08:58:26 +08:00
|
|
|
#include "query_engine/hardcode/queries.hpp"
|
2016-07-03 08:02:42 +08:00
|
|
|
|
|
|
|
using namespace std;
|
2016-07-02 05:05:03 +08:00
|
|
|
|
|
|
|
// --
|
|
|
|
// DESCRIPTION: create account
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL: CREATE (n:ACCOUNT {id: 50, name: "Nikola", country: "Croatia",
|
|
|
|
// created_at: 14634563}) RETURN n
|
2016-07-02 05:05:03 +08:00
|
|
|
// STRIPPED: CREATE(n:ACCOUNT{id:0,name:1,country:2,created_at:3})RETURNn
|
|
|
|
// HASH: 10597108978382323595
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: DONE
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: create personnel
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL: CREATE (n:PERSONNEL {id: 23, role: "CTO", created_at: 1235345})
|
|
|
|
// RETURN n
|
2016-07-02 05:05:03 +08:00
|
|
|
// STRIPPED: CREATE(n:PERSONNEL{id:0,role:1,created_at:2})RETURNn
|
2016-07-05 11:01:22 +08:00
|
|
|
// HASH: 4037885257628527960
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: TODO
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: create edge between ACCOUNT node and PERSONNEL node (IS type)
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL: MATCH (a:ACCOUNT {id:50}), (p:PERSONNEL {id: 23}) CREATE
|
|
|
|
// (a)-[:IS]->(p)
|
2016-07-02 05:05:03 +08:00
|
|
|
// STRIPPED: MATCH(a:ACCOUNT{id:0}),(p:PERSONNEL{id:1})CREATE(a)-[:IS]->(p)
|
2016-07-05 11:01:22 +08:00
|
|
|
// HASH: 16888190822925675190
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: TODO
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: find ACCOUNT node, PERSONNEL node and edge between them
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL: MATCH (a:ACCOUNT {id:50})-[r:IS]->(p:PERSONNEL {id: 23}) RETURN
|
|
|
|
// a,r,p
|
2016-07-02 05:05:03 +08:00
|
|
|
// STRIPPED: MATCH(a:ACCOUNT{id:0})-[r:IS]->(p:PERSONNEL{id:1})RETURNa,r,p
|
2016-07-05 11:01:22 +08:00
|
|
|
// HASH: 9672752533852902744
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: TODO
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: create OPPORTUNITY
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL:
|
|
|
|
// STRIPPED:
|
|
|
|
// HASH:
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: TODO
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: create PERSONNEL-[:CREATED]->OPPORTUNITY
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL:
|
|
|
|
// STRIPPED:
|
|
|
|
// HASH:
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: TODO
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: create COMPANY
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL:
|
|
|
|
// STRIPPED:
|
|
|
|
// HASH:
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: TODO
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: create OPPORTUNITY-[:MATCH]->COMPANY
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL:
|
|
|
|
// STRIPPED:
|
|
|
|
// HASH:
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: TODO
|
|
|
|
// --
|
|
|
|
// DESCRIPTION: create an edge between two nodes that are found by the ID
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL: MATCH (a {id:0}), (p {id: 1}) CREATE (a)-[r:IS]->(p) RETURN r
|
2016-07-03 08:02:42 +08:00
|
|
|
// STRIPPED: MATCH(a{id:0}),(p{id:1})CREATE(a)-[r:IS]->(p)RETURNr
|
2016-07-05 11:01:22 +08:00
|
|
|
// HASH: 7939106225150551899
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: DONE
|
2016-07-02 05:05:03 +08:00
|
|
|
// --
|
|
|
|
// DESCRIPTION: fine node by the ID
|
2016-07-03 08:02:42 +08:00
|
|
|
// FULL: MATCH (n {id: 0}) RETURN n
|
|
|
|
// STRIPPED: MATCH(n{id:0})RETURNn
|
2016-07-05 11:01:22 +08:00
|
|
|
// HASH: 11198568396549106428
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: DONE
|
|
|
|
// --
|
2016-07-02 05:05:03 +08:00
|
|
|
// DESCRIPTION: find edge by the ID
|
2016-07-03 08:02:42 +08:00
|
|
|
// FULL: MATCH ()-[r]-() WHERE ID(r)=0 RETURN r
|
|
|
|
// STRIPPED: MATCH()-[r]-()WHEREID(r)=0RETURNr
|
2016-07-05 11:01:22 +08:00
|
|
|
// HASH: 8320600413058284114
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: DONE
|
|
|
|
// --
|
|
|
|
// DESCRIPTION: update node that is found by the ID
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL: MATCH (n: {id: 0}) SET n.name = "TEST100" RETURN n
|
|
|
|
// STRIPPED: MATCH(n:{id:0})SETn.name=1RETURNn
|
|
|
|
// HASH: 6813335159006269041
|
2016-07-03 08:02:42 +08:00
|
|
|
// STATUS: DONE
|
|
|
|
// --
|
2016-07-02 05:05:03 +08:00
|
|
|
// DESCRIPTION: find shortest path between two nodes specified by ID
|
2016-07-05 11:01:22 +08:00
|
|
|
// FULL:
|
|
|
|
// STRIPPED:
|
|
|
|
// HASH:
|
|
|
|
// STATUS: TODO
|
|
|
|
// --
|
|
|
|
// DESCRIPTION: find all nodes by label name
|
|
|
|
// FULL: MATCH (n:LABEL) RETURN n
|
|
|
|
// STRIPPPED: MATCH(n:LABEL)RETURNn
|
|
|
|
// HASH: 4857652843629217005
|
2016-07-07 08:58:26 +08:00
|
|
|
// STATUS: DONE
|
2016-07-03 08:02:42 +08:00
|
|
|
// --
|
|
|
|
// TODO: Labels and Types have to be extracted from a query during the
|
|
|
|
// query compile time
|
|
|
|
|
2016-07-07 08:58:26 +08:00
|
|
|
// void cout_properties(const Properties &properties)
|
|
|
|
// {
|
|
|
|
// ConsoleWriter writer;
|
|
|
|
// properties.accept(writer);
|
|
|
|
// }
|
2016-07-02 05:05:03 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
int main(int argc, char **argv)
|
2016-07-02 05:05:03 +08:00
|
|
|
{
|
|
|
|
Db db;
|
2016-07-07 08:58:26 +08:00
|
|
|
auto queries = load_queries(db);
|
2016-07-03 08:02:42 +08:00
|
|
|
|
|
|
|
// auto arguments = all_arguments(argc, argv);
|
|
|
|
// auto input_query = extract_query(arguments);
|
2016-07-02 05:05:03 +08:00
|
|
|
auto stripper = make_query_stripper(TK_INT, TK_FLOAT, TK_STR, TK_BOOL);
|
2016-07-03 08:02:42 +08:00
|
|
|
// auto stripped = stripper.strip(input_query);
|
2016-07-05 11:01:22 +08:00
|
|
|
//
|
2016-07-03 08:02:42 +08:00
|
|
|
// auto time = timer<ms>([&stripped, &queries]() {
|
|
|
|
// for (int i = 0; i < 1000000; ++i) {
|
|
|
|
// queries[stripped.hash](stripped.arguments);
|
|
|
|
// }
|
|
|
|
// });
|
|
|
|
// std::cout << time << std::endl;
|
|
|
|
|
|
|
|
vector<string> history;
|
|
|
|
string command;
|
|
|
|
cout << "-- Memgraph query engine --" << endl;
|
|
|
|
do {
|
|
|
|
|
|
|
|
cout << "> ";
|
|
|
|
getline(cin, command);
|
|
|
|
history.push_back(command);
|
|
|
|
auto stripped = stripper.strip(command);
|
|
|
|
|
|
|
|
if (queries.find(stripped.hash) == queries.end()) {
|
|
|
|
cout << "unsupported query" << endl;
|
|
|
|
continue;
|
2016-07-02 05:05:03 +08:00
|
|
|
}
|
2016-07-05 11:01:22 +08:00
|
|
|
|
2016-07-03 08:02:42 +08:00
|
|
|
auto result = queries[stripped.hash](stripped.arguments);
|
|
|
|
cout << "RETURN: " << result << endl;
|
|
|
|
|
|
|
|
} while (command != "quit");
|
2016-07-02 05:05:03 +08:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|