cppjieba/src/Limonp/MysqlClient.hpp
2014-05-26 17:15:52 +08:00

126 lines
4.1 KiB
C++

#ifndef LIMONP_MYSQLCLIENT_H
#define LIMONP_MYSQLCLIENT_H
#include <mysql.h>
#include <iostream>
#include <vector>
#include <string>
#include "logger.hpp"
#include "InitOnOff.hpp"
namespace Limonp
{
using namespace std;
class MysqlClient: public InitOnOff
{
public:
typedef vector< vector<string> > RowsType;
private:
const string _host;
const size_t _port;
const string _user;
const string _passwd;
const string _db;
const string _charset;
public:
MysqlClient(const string& host, size_t port, const string& user, const string& passwd, const string& db, const string& charset = "utf8"): _host(host), _port(port), _user(user), _passwd(passwd), _db(db), _charset(charset), _conn(NULL)
{
_setInitFlag(_init());
}
~MysqlClient()
{
if(_conn)
{
mysql_close(_conn);
}
};
private:
bool _init()
{
//cout<<mysql_get_client_info()<<endl;
if(NULL == (_conn = mysql_init(NULL)))
{
LogError("mysql_init faield. %s", mysql_error(_conn));
return false;
}
if (mysql_real_connect(_conn, _host.c_str(), _user.c_str(), _passwd.c_str(), _db.c_str(), _port, NULL, 0) == NULL)
{
LogError("mysql_real_connect failed. %s", mysql_error(_conn));
mysql_close(_conn);
_conn = NULL;
return false;
}
if(mysql_set_character_set(_conn, _charset.c_str()))
{
LogError("mysql_set_character_set [%s] failed.", _charset.c_str());
return false;
}
//set reconenct
char value = 1;
mysql_options(_conn, MYSQL_OPT_RECONNECT, &value);
LogInfo("MysqlClient {host: %s, database:%s, charset:%s}", _host.c_str(), _db.c_str(), _charset.c_str());
return true;
}
public:
bool executeSql(const string& sql)
{
assert(_getInitFlag());
if(mysql_query(_conn, sql.c_str()))
{
LogError("mysql_query failed. %s", mysql_error(_conn));
return false;
}
return true;
}
size_t insert(const string& tableName, const string& keys, const vector<string>& vals)
{
size_t retn = 0;
string sql;
for(size_t i = 0; i < vals.size(); i ++)
{
sql.clear();
string_format(sql, "insert into %s (%s) values %s", tableName.c_str(), keys.c_str(), vals[i].c_str());
retn += executeSql(sql.c_str());
}
return retn;
}
bool select(const string& sql, RowsType& rows)
{
if(!executeSql(sql))
{
LogError("executeSql failed. [%s]", sql.c_str());
return false;
}
MYSQL_RES * result = mysql_store_result(_conn);
if(!result)
{
LogError("mysql_store_result failed.[%d]", mysql_error(_conn));
return false;
}
size_t num_fields = mysql_num_fields(result);
MYSQL_ROW row;
while((row = mysql_fetch_row(result)))
{
vector<string> vec;
for(size_t i = 0; i < num_fields; i ++)
{
row[i] ? vec.push_back(row[i]) : vec.push_back("NULL");
}
rows.push_back(vec);
}
mysql_free_result(result);
return true;
}
private:
MYSQL * _conn;
};
}
#endif