Files
mariadb-connector-cpp/install_test/example.cpp
Lawrin Novitsky 7983bc2d34 CONCPP-67 Fix of tarball directory structure
Added project, to ensure that example application can be built with
tarball headers and binaries
2021-02-10 21:50:23 +01:00

57 lines
2.0 KiB
C++

/************************************************************************************
Copyright (C) 2020 MariaDB Corporation AB
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this library; if not see <http://www.gnu.org/licenses>
or write to the Free Software Foundation, Inc.,
51 Franklin St., Fifth Floor, Boston, MA 02110, USA
*************************************************************************************/
#include <iostream>
#include <memory>
#include <regex>
#include "mariadb/conncpp.hpp"
int main()
{
// Instantiate Driver
sql::Driver* driver = sql::mariadb::get_driver_instance();
// Configure Connection
sql::SQLString url("jdbc:mariadb://localhost:3306/test");
sql::Properties properties({ {"user", "root"}, {"password", ""} });
// Establish Connection
try {
std::unique_ptr<sql::Connection> con(driver->connect(url, properties));
std::unique_ptr<sql::Statement> stmt(con->createStatement());
std::unique_ptr<sql::ResultSet> rs(stmt->executeQuery("SELECT 1, 'Hello world'"));
if (rs->next()) {
std::cout << rs->getInt(1) << rs->getString(2) << std::endl;
}
}
catch (sql::SQLSyntaxErrorException & e) {
std::cerr << "[" << e.getSQLState() << "] " << e.what() << "("<< e.getErrorCode() << ")" << std::endl;
}
catch (std::regex_error& e) {
std::cerr << "Regex exception:" << e.what() << std::endl;
}
catch (std::exception& e) {
std::cerr << "Standard exception:" << e.what() << std::endl;
}
return 0;
}