# A library for MySQL that implements a simpler framework for MySQL Connector++ A small framework for basic MySQL database operations via MySQL/Connector++ ## Features - Object oriented - Active connection pool - Retries to connect - Native C++ containers: vector, tuple - Response object - Thread safe - Exceptions ## Installation First install dependency MySQL/Connector++ ``` sudo apt install libmysqlcppconn-dev ``` Just download the latest release and unzip it into your project. You can turn it on with: ``` #include "mysql/lib/mysql.hpp" using namespace marcelb; ``` ## Usage ```c++ /** * Init */ MySQL mydb("tcp://192.168.2.10:3306", "user_nm", "passss", "my_db", 5); /** * Use ------------------ */ | | ------------------ | try { | | | | // execute | | | | auto response = mydb.exec("SELECT id,domain FROM records WHERE enabled = 0;"); // response is MySQL_Res type // check is execute cout << response.affected << " " << response.have_result << endl; cout << response.rows << " " << response.columns << endl; for (auto row : response) { // row is tuple type cout << get<0>(row) << " " << get<1>(row) << endl; } // access columns name for (auto column_name : response.columns_name) { cout << column_name << endl; } } catch (const string err) { cout << err << endl; } ``` ## License [APACHE 2.0](http://www.apache.org/licenses/LICENSE-2.0/) ## Support & Feedback For support and any feedback, contact the address: marcelb96@yahoo.com. ## Contributing Contributions are always welcome! Feel free to fork and start working with or without a later pull request. Or contact for suggest and request an option.