1#ifndef NEFORCE_DATABASE_PGSQL_CONNECT_HPP__
2#define NEFORCE_DATABASE_PGSQL_CONNECT_HPP__
11#ifdef NEFORCE_SUPPORT_POSTGRESQL
14NEFORCE_BEGIN_NAMESPACE__
44 ::PGconn* link_ =
nullptr;
45 mutable string last_error_{};
118 bool update(
const string& sql)
const override;
185NEFORCE_END_NAMESPACE__
NEFORCE_NODISCARD constexpr basic_string_view view(const size_type off, size_type count=npos) const
获取子视图
idb_factory(db_config config)
构造函数
bool update(const string &sql) const override
执行非查询SQL语句
NEFORCE_NODISCARD uint32_t get_errno() const override
获取最后错误码
NEFORCE_NODISCARD bool is_valid() const override
检查连接是否有效
unique_ptr< idb_prepared_statement > prepare_statement(const string &sql) const override
创建预处理语句
unique_ptr< idb_tb_result > query(const string &sql) const override
执行查询SQL语句
void close() override
关闭数据库连接
bool set_character_set(const string &encoding) const override
设置字符集
NEFORCE_NODISCARD bool connect(const db_config &config) override
建立数据库连接
NEFORCE_NODISCARD string_view get_character_set() const override
获取当前字符集
NEFORCE_NODISCARD bool connected() const override
检查连接是否已建立
bool reconnect(const db_config &config) override
重新连接数据库
NEFORCE_NODISCARD string_view get_error() const override
获取最后错误信息
pgsql_connect()=default
默认构造函数
~pgsql_connect() override
析构函数
idb_result * create_result(void *native_result) override
创建PostgreSQL结果集对象
pgsql_factory(db_config config)
构造函数
idb_connect * create_connect() override
创建PostgreSQL连接对象
~pgsql_factory() override=default
析构函数
unsigned int uint32_t
32位无符号整数类型
constexpr Iterator2 move(Iterator1 first, Iterator1 last, Iterator2 result) noexcept(noexcept(inner::__move_aux(first, last, result)))
移动范围元素
basic_string_view< char > string_view
字符字符串视图
virtual bool connected() const =0
检查连接状态
virtual void close()=0
关闭连接