Implement typed execute, typed response, clear for unnecessary requests, delete incomplete SQL_QA type, etc.
This commit is contained in:
		
							parent
							
								
									6201fe0225
								
							
						
					
					
						commit
						6129774980
					
				
							
								
								
									
										43
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										43
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @ -18,6 +18,47 @@ | ||||
|         "thread": "cpp", | ||||
|         "chrono": "cpp", | ||||
|         "sstream": "cpp", | ||||
|         "map": "cpp" | ||||
|         "map": "cpp", | ||||
|         "cctype": "cpp", | ||||
|         "clocale": "cpp", | ||||
|         "cmath": "cpp", | ||||
|         "cstdarg": "cpp", | ||||
|         "cstddef": "cpp", | ||||
|         "cstdio": "cpp", | ||||
|         "cstdlib": "cpp", | ||||
|         "cstring": "cpp", | ||||
|         "ctime": "cpp", | ||||
|         "cwchar": "cpp", | ||||
|         "cwctype": "cpp", | ||||
|         "atomic": "cpp", | ||||
|         "bit": "cpp", | ||||
|         "compare": "cpp", | ||||
|         "concepts": "cpp", | ||||
|         "condition_variable": "cpp", | ||||
|         "cstdint": "cpp", | ||||
|         "list": "cpp", | ||||
|         "unordered_map": "cpp", | ||||
|         "exception": "cpp", | ||||
|         "algorithm": "cpp", | ||||
|         "functional": "cpp", | ||||
|         "iterator": "cpp", | ||||
|         "memory": "cpp", | ||||
|         "memory_resource": "cpp", | ||||
|         "numeric": "cpp", | ||||
|         "random": "cpp", | ||||
|         "ratio": "cpp", | ||||
|         "system_error": "cpp", | ||||
|         "tuple": "cpp", | ||||
|         "type_traits": "cpp", | ||||
|         "iosfwd": "cpp", | ||||
|         "istream": "cpp", | ||||
|         "limits": "cpp", | ||||
|         "numbers": "cpp", | ||||
|         "semaphore": "cpp", | ||||
|         "stdexcept": "cpp", | ||||
|         "stop_token": "cpp", | ||||
|         "streambuf": "cpp", | ||||
|         "cinttypes": "cpp", | ||||
|         "typeinfo": "cpp" | ||||
|     } | ||||
| } | ||||
							
								
								
									
										34
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								README.md
									
									
									
									
									
								
							| @ -9,8 +9,8 @@ A small framework for basic MySQL database operations via MySQL/Connector++ | ||||
| - Object oriented | ||||
| - Active connection pool | ||||
| - Retries to connect | ||||
| - Native C++ containers: map, vector | ||||
| - QA object | ||||
| - Native C++ containers: vector, tuple | ||||
| - Response object | ||||
| - Thread safe | ||||
| - Exceptions | ||||
| 
 | ||||
| @ -35,26 +35,24 @@ using namespace marcelb; | ||||
| /** | ||||
| * Init | ||||
| */ | ||||
| mySQL mydb("tcp://192.168.2.10:3306", "user_nm", "passss", "my_db", 5); | ||||
| MySQL mydb("tcp://192.168.2.10:3306", "user_nm", "passss", "my_db", 5); | ||||
| 
 | ||||
| /** | ||||
| * Use | ||||
| */ | ||||
| sqlQA test_qa; | ||||
| // build qa | ||||
| test_qa.select().from("records").where("enabled = 1"); | ||||
| try { | ||||
|     // execute | ||||
|     mydb.exec(test_qa); | ||||
| * Use                                 ------------------               | ||||
| */                                   |                  |     | ||||
|                                  ------------------     | | ||||
| try {                           |    |              |   | | ||||
|     // execute                  |    |              |   | | ||||
|     auto response = mydb.exec<int,string>("SELECT id,domain FROM records WHERE enabled = 0;"); | ||||
|     // response is MySQL_Res<int,string> type | ||||
|     // check is execute | ||||
|     if (test_qa.executed) { | ||||
|         // print | ||||
|         test_qa.print(true); | ||||
|         // access to first result of column id | ||||
|         cout << test_qa.result["id"][0] << endl; | ||||
|         // num of returned rows and columns | ||||
|         cout << test_qa.num_rows << " " << test_qa.num_columns << endl; | ||||
|     cout << response.affected << " " << response.have_result << endl; | ||||
|     cout << response.rows << " " << response.columns << endl; | ||||
| 
 | ||||
|     for (auto row : response) { // row is tuple<int,string> type | ||||
|         cout << get<0>(row) << " " << get<1>(row) << endl; | ||||
|     } | ||||
| 
 | ||||
| } catch (const string err) { | ||||
|     cout << err << endl; | ||||
| } | ||||
|  | ||||
							
								
								
									
										15
									
								
								lib/core_orm.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								lib/core_orm.hpp
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | ||||
| #ifndef _MYSQL_CORE_ORM_ | ||||
| #define _MYSQL_CORE_ORM_ | ||||
| 
 | ||||
| using namespace std; | ||||
| 
 | ||||
| namespace marcelb { | ||||
| 
 | ||||
| /**
 | ||||
|  * Implementiraj klase za ORM koje će se ekstendati | ||||
| */ | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										117
									
								
								lib/mysql.hpp
									
									
									
									
									
								
							
							
						
						
									
										117
									
								
								lib/mysql.hpp
									
									
									
									
									
								
							| @ -5,8 +5,10 @@ | ||||
| #include <mutex> | ||||
| #include <thread> | ||||
| #include <future> | ||||
| 
 | ||||
| #include "sqlqa.hpp" | ||||
| // #include <iostream>
 | ||||
| #include <string> | ||||
| #include <vector> | ||||
| #include <tuple> | ||||
| 
 | ||||
| #include <mysql_driver.h> | ||||
| #include <mysql_connection.h> | ||||
| @ -25,7 +27,59 @@ using namespace mysql; | ||||
| 
 | ||||
| namespace marcelb { | ||||
| 
 | ||||
| class mySQL { | ||||
| /**
 | ||||
|  * A class for creating sql responses | ||||
| */ | ||||
| template<typename... Types>  | ||||
| class MySQL_Res : public vector<tuple<Types...>> { | ||||
|     public: | ||||
|     bool have_result = false; | ||||
|     uint16_t affected = 0; | ||||
|     uint16_t rows = 0; | ||||
|     uint16_t columns = (int)tuple_size<tuple<Types...>>::value; | ||||
| }; | ||||
| 
 | ||||
| /**
 | ||||
|  * Type conversion functions | ||||
| */ | ||||
| 
 | ||||
| template<typename T> | ||||
| T getValue(ResultSet* res, int column); | ||||
| template<> | ||||
| inline int getValue<int>(ResultSet* res, int column) { | ||||
|     return res->getInt(column); | ||||
| } | ||||
| template<>  | ||||
| inline uint getValue<uint>(ResultSet* res, int column) { | ||||
|     return res->getUInt(column); | ||||
| } | ||||
| template<> | ||||
| inline int64_t getValue<int64_t>(ResultSet* res, int column) { | ||||
|     return res->getInt64(column); | ||||
| } | ||||
| template<> | ||||
| inline uint64_t getValue<uint64_t>(ResultSet* res, int column) { | ||||
|     return res->getUInt64(column); | ||||
| } | ||||
| template<> | ||||
| inline float getValue<float>(ResultSet* res, int column) { | ||||
|     return res->getDouble(column); | ||||
| } | ||||
| template<> | ||||
| inline double getValue<double>(ResultSet* res, int column) { | ||||
|     return res->getDouble(column); | ||||
| } | ||||
| template<> | ||||
| inline string getValue<string>(ResultSet* res, int column) { | ||||
|     return res->getString(column); | ||||
| } | ||||
| template<> | ||||
| inline bool getValue<bool>(ResultSet* res, int column) { | ||||
|     return res->getBoolean(column); | ||||
| } | ||||
| // implementiraj neku c++ kompatibilnu pretvorbu za timestampe, time, date datetime itd.
 | ||||
| 
 | ||||
| class MySQL { | ||||
|     mutex io; | ||||
|     MySQL_Driver *drv; | ||||
|     deque<Connection*> con; | ||||
| @ -35,11 +89,6 @@ class mySQL { | ||||
|     bool runBot = true; | ||||
|     future<void> bot; | ||||
|      | ||||
|     /**
 | ||||
|      * Get column names for a table | ||||
|     */ | ||||
|     void getColumns(const string _table, vector<string> &_columns, Connection *ptr_con); // privatno
 | ||||
|      | ||||
|     /**
 | ||||
|      * Open one database | ||||
|     */ | ||||
| @ -60,15 +109,24 @@ class mySQL { | ||||
|     */ | ||||
|     Connection* shift_con(); | ||||
| 
 | ||||
|     /**
 | ||||
|      * Function parses a parameterized row | ||||
|     */ | ||||
| 
 | ||||
|     template<typename... Types, size_t... Is> | ||||
|     static tuple<Types...> getRow(sql::ResultSet* res, index_sequence<Is...>) { | ||||
|         return make_tuple(getValue<Types>(res, Is + 1)...); | ||||
|     } | ||||
| 
 | ||||
|     public: | ||||
| 
 | ||||
|     /**
 | ||||
|      * mySQL constructor, | ||||
|      * MySQL constructor, | ||||
|      * receive the path to the mysql server,  | ||||
|      * username, password, database name, | ||||
|      * and number of active connections (optional) | ||||
|     */ | ||||
|     mySQL(const string _path, const string _username, const string _password, const string _db, const uint _available = 1); | ||||
|     MySQL(const string _path, const string _username, const string _password, const string _db, const uint _available = 1); | ||||
| 
 | ||||
|     /**
 | ||||
|      * Disconnect all connections to server | ||||
| @ -82,15 +140,48 @@ class mySQL { | ||||
|     void reconnectTrys(const uint _trys); | ||||
| 
 | ||||
|     /**
 | ||||
|      * Execute SQLQA | ||||
|      * Execute the SQL statement | ||||
|     */ | ||||
|     void exec(sqlQA &sql_qa); | ||||
|     template<typename... Types>  | ||||
|     MySQL_Res<Types...> exec(const string& sql_q) { | ||||
|         Connection* con_ptr = shift_con();  | ||||
|         MySQL_Res<Types...> result; | ||||
|          | ||||
|         try { | ||||
|             Statement *stmt; | ||||
|             stmt = con_ptr->createStatement(); | ||||
|             result.have_result = stmt->execute(sql_q); | ||||
| 
 | ||||
|             if (result.have_result) { | ||||
|                 ResultSet* res = stmt->getResultSet(); | ||||
|                 result.rows = res->rowsCount(); | ||||
| 
 | ||||
|                 while (res->next()) { | ||||
|                     result.push_back(MySQL::getRow<Types...>(res, std::make_index_sequence<sizeof...(Types)>{})); | ||||
|                 } | ||||
| 
 | ||||
|                 res->close(); | ||||
|                 delete res; | ||||
|             } else { | ||||
|                 result.affected = stmt->getUpdateCount(); | ||||
|             } | ||||
| 
 | ||||
|             stmt->close(); | ||||
|             delete stmt; | ||||
|             disconnect_one(con_ptr); | ||||
| 
 | ||||
|         } catch (sql::SQLException& e) { | ||||
|             throw runtime_error(e.what()); | ||||
|         } | ||||
| 
 | ||||
|         return result; | ||||
|     } | ||||
| 
 | ||||
|     /**
 | ||||
|      * Destruktor | ||||
|      * close all connections | ||||
|     */ | ||||
|     ~mySQL(); | ||||
|     ~MySQL(); | ||||
| 
 | ||||
| }; | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										119
									
								
								lib/sqlqa.hpp
									
									
									
									
									
								
							
							
						
						
									
										119
									
								
								lib/sqlqa.hpp
									
									
									
									
									
								
							| @ -1,119 +0,0 @@ | ||||
| #ifndef _SQLQA_ | ||||
| #define _SQLQA_ | ||||
| 
 | ||||
| #include <iostream> | ||||
| #include <sstream> | ||||
| #include <string> | ||||
| #include <vector> | ||||
| #include <map> | ||||
| 
 | ||||
| using namespace std; | ||||
| 
 | ||||
| namespace marcelb { | ||||
| 
 | ||||
| /**
 | ||||
|  * A class for creating sql queries and responses | ||||
| */ | ||||
| class sqlQA { | ||||
|     public: | ||||
|     // query variable list
 | ||||
| 
 | ||||
|     // SQL Command
 | ||||
|     string cmd; | ||||
|     // Table name
 | ||||
|     string table; | ||||
|     // Columns name list
 | ||||
|     vector<string> columns; | ||||
|     // Query is update type
 | ||||
|     bool isUpdate = false; | ||||
|     // Query is select type
 | ||||
|     bool isSelect = false; | ||||
| 
 | ||||
|     // answer
 | ||||
| 
 | ||||
|     // Number of updates caught
 | ||||
|     uint updateCatch = 0; | ||||
|     // Executing status
 | ||||
|     bool executed = false; | ||||
|     // Answer
 | ||||
|     map<string, vector<string>> result; | ||||
|     // Number of returned rows
 | ||||
|     uint num_rows = 0; | ||||
|     // Number of returned columns
 | ||||
|     uint num_columns = 0; | ||||
| 
 | ||||
|     // query methods
 | ||||
| 
 | ||||
|     /**
 | ||||
|      * SELECT | ||||
|      * accept columns names, comma separated   | ||||
|      * defualt * | ||||
|     */ | ||||
|     sqlQA& select(const string _select = "*"); | ||||
| 
 | ||||
|     /**
 | ||||
|      * FROM | ||||
|      * accept table name | ||||
|     */ | ||||
|     sqlQA& from(const string _tablename); | ||||
| 
 | ||||
|     /**
 | ||||
|      * WHERE | ||||
|      * accept string sql condition | ||||
|     */ | ||||
|     sqlQA& where(const string _condition); | ||||
| 
 | ||||
|     /**
 | ||||
|      * LIMIT | ||||
|      * set limit result | ||||
|     */ | ||||
|     sqlQA& limit(const uint _limit); | ||||
| 
 | ||||
|     /**
 | ||||
|      * INSERT IN TO | ||||
|      * accept table name, and columns | ||||
|     */ | ||||
|     sqlQA& insertInTo(const string _tablename, const string _columns = ""); | ||||
| 
 | ||||
|     /**
 | ||||
|      * VALUES | ||||
|      * accept values | ||||
|     */ | ||||
|     sqlQA& values(const string _values); | ||||
| 
 | ||||
|     /**
 | ||||
|      * UPDATE | ||||
|      * accept tablename for update query | ||||
|     */ | ||||
|     sqlQA& update(const string _tablename); | ||||
| 
 | ||||
|     /**
 | ||||
|      * SET | ||||
|      * accept column and value pairs | ||||
|     */ | ||||
|     sqlQA& set(const string _column_value_pairs); | ||||
| 
 | ||||
|     /**
 | ||||
|      * DELETE FROM | ||||
|      * accept table name | ||||
|     */ | ||||
|     sqlQA& deleteFrom(const string _table); | ||||
| 
 | ||||
|     /**
 | ||||
|      * Print SQLQA | ||||
|     */ | ||||
|     void print(bool withDetail = false); | ||||
| 
 | ||||
|     // intern methods
 | ||||
|     private: | ||||
| 
 | ||||
|     /**
 | ||||
|      * Parse column names | ||||
|     */ | ||||
|     void parse_columns(const string _cloumns); | ||||
| }; | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
| @ -1,7 +1,7 @@ | ||||
| #include "../lib/mysql.hpp" | ||||
| 
 | ||||
| 
 | ||||
| marcelb::mySQL::mySQL(const string _path, const string _username, const string _password, const string _db, const uint _available) { | ||||
| marcelb::MySQL::MySQL(const string _path, const string _username, const string _password, const string _db, const uint _available) { | ||||
|    path = _path; | ||||
|    username = _username; | ||||
|    password = _password; | ||||
| @ -46,7 +46,7 @@ marcelb::mySQL::mySQL(const string _path, const string _username, const string _ | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| Connection* marcelb::mySQL::create_con() { | ||||
| Connection* marcelb::MySQL::create_con() { | ||||
|    uint trys = 0; | ||||
|    bool status = true; | ||||
|    Connection* new_con = NULL; | ||||
| @ -72,7 +72,7 @@ Connection* marcelb::mySQL::create_con() { | ||||
|    return new_con; | ||||
| } | ||||
| 
 | ||||
| bool marcelb::mySQL::disconnect() { | ||||
| bool marcelb::MySQL::disconnect() { | ||||
|    io.lock(); | ||||
|    bool status = true; | ||||
| 
 | ||||
| @ -84,7 +84,7 @@ bool marcelb::mySQL::disconnect() { | ||||
|    return status; | ||||
| } | ||||
| 
 | ||||
| bool marcelb::mySQL::disconnect_one(Connection* con_ptr) { | ||||
| bool marcelb::MySQL::disconnect_one(Connection* con_ptr) { | ||||
|    bool status = !con_ptr->isClosed(); | ||||
| 
 | ||||
|    if (status) { | ||||
| @ -106,7 +106,7 @@ bool marcelb::mySQL::disconnect_one(Connection* con_ptr) { | ||||
|    return status; | ||||
| } | ||||
| 
 | ||||
| bool marcelb::mySQL::open_one(Connection* con_ptr) { | ||||
| bool marcelb::MySQL::open_one(Connection* con_ptr) { | ||||
|    bool status = true; // ako true greška je
 | ||||
|    uint trys = 0; | ||||
| 
 | ||||
| @ -134,83 +134,13 @@ bool marcelb::mySQL::open_one(Connection* con_ptr) { | ||||
|  * Broj pokušaja usljed povezivanja s bazom od 1 do unlimited; | ||||
| */ | ||||
| 
 | ||||
| void marcelb::mySQL::reconnectTrys(const uint _trys) { | ||||
| void marcelb::MySQL::reconnectTrys(const uint _trys) { | ||||
|    io.lock(); | ||||
|    reconTrys = _trys; | ||||
|    io.unlock(); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void marcelb::mySQL::exec(sqlQA &sql_qa) { | ||||
|    Connection* con_ptr = shift_con();  | ||||
| 
 | ||||
|    try { | ||||
|       vector<string> columns = sql_qa.columns; | ||||
|        | ||||
|       if (columns.empty() && !sql_qa.table.empty()) { | ||||
|          getColumns(sql_qa.table, columns, con_ptr); | ||||
|       } | ||||
| 
 | ||||
|       Statement *stmt; | ||||
|       stmt = con_ptr->createStatement(); | ||||
| 
 | ||||
|       if (sql_qa.isSelect) { | ||||
|          ResultSet *res = stmt->executeQuery(sql_qa.cmd); | ||||
|          sql_qa.executed = true; | ||||
|          uint num_raw_columns = 0; | ||||
|          while (res->next()) { | ||||
|             for (uint i=0; i<columns.size(); i++) { | ||||
|                sql_qa.result[columns[i]].push_back(res->getString(columns[i])); | ||||
|                num_raw_columns++; | ||||
|             } | ||||
|          } | ||||
| 
 | ||||
|          res->close(); | ||||
|          delete res; | ||||
|          sql_qa.num_columns = columns.size(); | ||||
|          sql_qa.num_rows = num_raw_columns/columns.size(); | ||||
|       } | ||||
| 
 | ||||
|       if (sql_qa.isUpdate) { | ||||
|          sql_qa.updateCatch = stmt->executeUpdate(sql_qa.cmd); | ||||
|          sql_qa.executed = true; | ||||
|       } | ||||
| 
 | ||||
|       else { | ||||
|          sql_qa.executed = stmt->execute(sql_qa.cmd); | ||||
|       } | ||||
| 
 | ||||
|       stmt->close(); | ||||
|       delete stmt; | ||||
|       disconnect_one(con_ptr); | ||||
|    } | ||||
|    catch (const SQLException &error) { | ||||
|       cout << error.what() << endl; | ||||
|       sql_qa.executed = false; | ||||
|    } | ||||
|    catch (const string error) { | ||||
|       throw error; | ||||
|    } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void marcelb::mySQL::getColumns(const string _table, vector<string> &_columns, Connection *ptr_con) { | ||||
|    Statement *stmt; | ||||
|    stmt = ptr_con->createStatement(); | ||||
|     | ||||
|    ResultSet *columnsRes = stmt->executeQuery("SHOW COLUMNS from " + _table); | ||||
| 
 | ||||
|    while (columnsRes->next()) { | ||||
|       _columns.push_back(columnsRes->getString("Field")); | ||||
|    } | ||||
| 
 | ||||
|    columnsRes->close(); | ||||
|    stmt->close(); | ||||
|    delete columnsRes; | ||||
|    delete stmt; | ||||
| } | ||||
| 
 | ||||
| Connection* marcelb::mySQL::shift_con() { | ||||
| Connection* marcelb::MySQL::shift_con() { | ||||
|    while (true) { | ||||
|       while(con.size()) { | ||||
|          io.lock(); | ||||
| @ -226,7 +156,7 @@ Connection* marcelb::mySQL::shift_con() { | ||||
|    } | ||||
| } | ||||
| 
 | ||||
| marcelb::mySQL::~mySQL() { | ||||
| marcelb::MySQL::~MySQL() { | ||||
|    runBot = false; | ||||
|    bot.get(); | ||||
|    disconnect(); | ||||
|  | ||||
| @ -1,97 +0,0 @@ | ||||
| #include "../lib/sqlqa.hpp" | ||||
| 
 | ||||
| using namespace marcelb; | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::select(const string _columns) { | ||||
|    if (_columns != "*") { | ||||
|       parse_columns(_columns); | ||||
|    } | ||||
|    isSelect = true; | ||||
|    cmd += "SELECT " + _columns + " "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::from(const string _table) { | ||||
|    table = _table; | ||||
|    cmd += "FROM " + _table + " "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::where(const string _condition) { | ||||
|    cmd += "WHERE " + _condition + " "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::limit(const uint _limit) { | ||||
|    cmd += "LIMIT " + to_string(_limit) + " "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::insertInTo(const string _tablename, const string _columns) { | ||||
|    isUpdate = true; | ||||
|    cmd += "INSERT INTO " + _tablename; | ||||
|    if (_columns.empty()) { | ||||
|       cmd += " "; | ||||
|    } | ||||
|    else { | ||||
|       cmd += " (" + _columns + ") "; | ||||
|    } | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::values(const string _values) { | ||||
|    cmd += "VALUES (" + _values + ") "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::update(const string _table) { | ||||
|    isUpdate = true; | ||||
|    cmd += "UPDATE " + _table + " "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::set(const string _column_value_pairs) { | ||||
|    cmd += "SET " + _column_value_pairs + " "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| sqlQA& marcelb::sqlQA::deleteFrom(const string _table) { | ||||
|    isUpdate = true; | ||||
|    cmd += "DELETE FROM " + _table + " "; | ||||
|    return *this; | ||||
| } | ||||
| 
 | ||||
| void marcelb::sqlQA::print(bool withDetail) { | ||||
|    cout << "============================================" << endl; | ||||
| 
 | ||||
|    for (auto i : result) { | ||||
|       for (auto j: i.second) { | ||||
|          cout << i.first << " : " << j << endl; | ||||
|       } | ||||
|       cout << "--------------------------------------------" << endl; | ||||
|    } | ||||
| 
 | ||||
|    if (withDetail) { | ||||
|       cout << "-----------------DETAILS--------------------" << endl; | ||||
|       cout << "Is executed: " << (executed ? "true" : "false") << endl; | ||||
|       cout << "Update catch: " << updateCatch << endl; | ||||
|       cout << "Num of rows: " << num_rows << endl; | ||||
|       cout << "Num of columns: " << num_columns << endl; | ||||
|    } | ||||
|    cout << "============================================" << endl; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void marcelb::sqlQA::parse_columns(const string _columns) { | ||||
|    istringstream iss(_columns); | ||||
|    string columnName; | ||||
| 
 | ||||
|    while (getline(iss, columnName, ',')) { | ||||
|       size_t startPos = columnName.find_first_not_of(" "); | ||||
|       size_t endPos = columnName.find_last_not_of(" "); | ||||
|        | ||||
|       if (startPos != string::npos && endPos != string::npos) { | ||||
|          columns.push_back(columnName.substr(startPos, endPos - startPos + 1)); | ||||
|       } | ||||
|    } | ||||
| } | ||||
| @ -10,10 +10,10 @@ using namespace marcelb; | ||||
| 
 | ||||
| int main() { | ||||
|     try { | ||||
|         // mySQL mydb("tcp://192.168.2.10:3306", "dinio", "H€r5elfInd1aH@nds", "dinio", 1);
 | ||||
|         mySQL mydb("tcp://192.168.2.10:3306", "dinio", "H€r5elfInd1aH@nds", "dinio", 5); | ||||
|         // MySQL mydb("tcp://192.168.2.10:3306", "dinio", "H€r5elfInd1aH@nds", "dinio", 1);
 | ||||
|         MySQL mydb("tcp://192.168.2.10:3306", "dinio", "H€r5elfInd1aH@nds", "dinio", 5); | ||||
| 
 | ||||
|         // sleep(3600*10);
 | ||||
|         sleep(2); | ||||
| 
 | ||||
| 
 | ||||
|         auto start = high_resolution_clock::now(); | ||||
| @ -100,35 +100,46 @@ int main() { | ||||
| 
 | ||||
| //        one by one
 | ||||
|         try { | ||||
|             sqlQA test_qa; | ||||
|             test_qa.select().from("records").where("enabled = 1"); | ||||
|             mydb.exec(test_qa); | ||||
|             test_qa.print(true); | ||||
|             // sqlQA test_qa;
 | ||||
|             // test_qa.select("id,domain").from("records").where("enabled = 1");
 | ||||
|             // cout << test_qa.cmd << endl;
 | ||||
|             // mydb.exec(test_qa);
 | ||||
|             // test_qa.print(true);
 | ||||
| 
 | ||||
|             auto response =  mydb.exec<int,string>("SELECT id,domain FROM records WHERE enabled = 0;"); | ||||
|             // auto response =  mydb.exec<int,string>("UPDATE records SET enabled = 1;");
 | ||||
|             cout << response.affected << " " << response.have_result << endl; | ||||
|             cout << response.rows << " " << response.columns << endl; | ||||
| 
 | ||||
|             for (auto row : response) { | ||||
|                 cout << get<0>(row) << " " << get<1>(row) << endl; | ||||
|             } | ||||
| 
 | ||||
|         } catch (const string err) { | ||||
|             cout << err << endl; | ||||
|         } | ||||
| 
 | ||||
|         sleep(20); | ||||
|         // sleep(20);
 | ||||
|      | ||||
|         try { | ||||
|             sqlQA test_qa; | ||||
|             test_qa.select().from("users"); | ||||
|             mydb.exec(test_qa); | ||||
|             test_qa.print(true); | ||||
|         } catch (const string err) { | ||||
|             cout << err << endl; | ||||
|         } | ||||
|         // try {
 | ||||
|         //     sqlQA test_qa;
 | ||||
|         //     test_qa.select().from("users");
 | ||||
|         //     mydb.exec(test_qa);
 | ||||
|         //     test_qa.print(true);
 | ||||
|         // } catch (const string err) {
 | ||||
|         //     cout << err << endl;
 | ||||
|         // }
 | ||||
| 
 | ||||
|         sleep(20); | ||||
|         // sleep(20);
 | ||||
| 
 | ||||
|         try { | ||||
|             sqlQA test_qa; | ||||
|             test_qa.select("zone_id,record_type,enabled").from("records").where("domain = 'bitelex.test'"); | ||||
|             mydb.exec(test_qa); | ||||
|             test_qa.print(true); | ||||
|         } catch (const string err) { | ||||
|             cout << err << endl; | ||||
|         } | ||||
|         // try {
 | ||||
|         //     sqlQA test_qa;
 | ||||
|         //     test_qa.select("zone_id,record_type,enabled").from("records").where("domain = 'bitelex.test'");
 | ||||
|         //     mydb.exec(test_qa);
 | ||||
|         //     test_qa.print(true);
 | ||||
|         // } catch (const string err) {
 | ||||
|         //     cout << err << endl;
 | ||||
|         // }
 | ||||
| 
 | ||||
| 
 | ||||
|         auto end = high_resolution_clock::now(); | ||||
|  | ||||
							
								
								
									
										
											BIN
										
									
								
								test/test.o
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								test/test.o
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user