acl/lib_acl_cpp/include/acl_cpp/db/db_pgsql.hpp

109 lines
2.0 KiB
C++

#pragma once
#include "../acl_cpp_define.hpp"
#include "../stdlib/string.hpp"
#include "../db/db_handle.hpp"
#if !defined(ACL_CLIENT_ONLY) && !defined(ACL_DB_DISABLE)
typedef struct pg_conn PGconn;
namespace acl {
class pgsql_conf;
class ACL_CPP_API db_pgsql : public db_handle {
public:
db_pgsql(const pgsql_conf& conf);
~db_pgsql(void);
static bool load(void);
/********************************************************************/
/* 以下为基类 db_handle 的虚接口 */
/********************************************************************/
const char* dbtype(void) const;
/**
* @override
*/
int get_errno(void) const;
/**
* @override
*/
const char* get_error(void) const;
/**
* @override
*/
bool dbopen(const char* charset = NULL);
/**
* @override
*/
bool is_opened(void) const;
/**
* @override
*/
bool close(void);
/**
* @override
*/
bool tbl_exists(const char* tbl_name);
/**
* @override
*/
bool sql_select(const char* sql, db_rows* result = NULL);
/**
* @override
*/
bool sql_update(const char* sql);
/**
* @override
*/
int affect_count(void) const;
/**
* @override
*/
bool begin_transaction(void);
/**
* @override
*/
bool commit(void);
/**
* @override
*/
bool rollback(void);
private:
char* dbaddr_; // 数据库监听地址
char* dbname_; // 数据库名
char* dbuser_; // 数据库账号
char* dbpass_; // 数据库账号密码
string charset_; // 连接数据库采用的字符集
int conn_timeout_;
int rw_timeout_;
PGconn* conn_;
int affect_count_;
void sane_pgsql_init(const char* dbaddr, const char* dbname,
const char* dbuser, const char* dbpass, int conn_timeout,
int rw_timeout, const char* charset);
void* sane_pgsql_query(const char* sql);
};
} // namespace acl
#endif // !defined(ACL_CLIENT_ONLY) && !defined(ACL_DB_DISABLE)