NexusForce 1.0.0
A Modern C++ Library with extended functionality, web components, and utility libraries
载入中...
搜索中...
未找到
mysql_connect.hpp
浏览该文件的文档.
1#ifndef NEFORCE_DATABASE_MYSQL_CONNECT_HPP__
2#define NEFORCE_DATABASE_MYSQL_CONNECT_HPP__
3
10
11#ifdef NEFORCE_SUPPORT_MYSQL
12# include <mysql/mysql.h>
14NEFORCE_BEGIN_NAMESPACE__
15
21
27
41struct NEFORCE_API mysql_connect final : idb_tb_connect {
42private:
43 ::MYSQL* link_ = nullptr;
44
45public:
51 mysql_connect() { link_ = ::mysql_init(nullptr); }
52
58 ~mysql_connect() noexcept override { close(); }
59
67 NEFORCE_NODISCARD bool connect(const db_config& config) noexcept override;
68
76 NEFORCE_NODISCARD bool reconnect(const db_config& config) override;
77
81 void close() noexcept override;
82
88 NEFORCE_NODISCARD bool set_character_set(const string& encoding) const noexcept override;
89
96 NEFORCE_NODISCARD bool set_options(::mysql_option option, const string& str) const noexcept;
97
102 NEFORCE_NODISCARD string_view get_character_set() const noexcept override;
103
108 NEFORCE_NODISCARD string_view get_error() const noexcept override;
109
114 NEFORCE_NODISCARD uint32_t get_errno() const noexcept override;
115
121 NEFORCE_NODISCARD bool update(const string& sql) const noexcept override;
122
128 NEFORCE_NODISCARD unique_ptr<idb_tb_result> query(const string& sql) const noexcept override;
129
136 NEFORCE_NODISCARD unique_ptr<idb_prepared_statement> prepare_statement(const string& sql) const override;
137
142 NEFORCE_NODISCARD bool connected() const noexcept override { return link_ != nullptr; }
143
148 NEFORCE_NODISCARD bool is_valid() const noexcept override { return ::mysql_ping(link_) == 0; }
149};
150
157class NEFORCE_API mysql_factory final : public idb_factory {
158public:
163 explicit mysql_factory(db_config config) :
164 idb_factory(move(config)) {}
165
171
177 idb_result* create_result(void* native_result) override;
178};
179 // MySQL
181 // Database
183
184NEFORCE_END_NAMESPACE__
185#endif // NEFORCE_SUPPORT_MYSQL
186#endif // NEFORCE_DATABASE_MYSQL_CONNECT_HPP__
idb_factory(db_config config)
构造函数
idb_result * create_result(void *native_result) override
创建MySQL结果集对象
idb_connect * create_connect() override
创建MySQL连接对象
mysql_factory(db_config config)
构造函数
独占智能指针
数据库抽象接口层
unsigned int uint32_t
32位无符号整数类型
@ MYSQL
MySQL数据库
constexpr Iterator2 move(Iterator1 first, Iterator1 last, Iterator2 result) noexcept(noexcept(inner::__move_aux(first, last, result)))
移动范围元素
basic_string_view< char > string_view
字符字符串视图
数据库连接配置结构
数据库连接抽象基类
virtual void close()=0
关闭连接
预处理语句抽象基类
数据库结果集抽象基类
关系型数据库连接抽象基类
关系型数据库结果集抽象基类
NEFORCE_NODISCARD unique_ptr< idb_tb_result > query(const string &sql) const noexcept override
执行查询SQL语句
NEFORCE_NODISCARD uint32_t get_errno() const noexcept override
获取最后错误码
NEFORCE_NODISCARD bool reconnect(const db_config &config) override
重新连接数据库
NEFORCE_NODISCARD bool set_character_set(const string &encoding) const noexcept override
设置字符集
NEFORCE_NODISCARD bool set_options(::mysql_option option, const string &str) const noexcept
设置MySQL连接选项
mysql_connect()
构造函数
void close() noexcept override
关闭数据库连接
~mysql_connect() noexcept override
析构函数
NEFORCE_NODISCARD bool update(const string &sql) const noexcept override
执行非查询SQL语句
NEFORCE_NODISCARD string_view get_character_set() const noexcept override
获取当前字符集
NEFORCE_NODISCARD unique_ptr< idb_prepared_statement > prepare_statement(const string &sql) const override
创建预处理语句
NEFORCE_NODISCARD bool is_valid() const noexcept override
检查连接是否有效
NEFORCE_NODISCARD bool connect(const db_config &config) noexcept override
建立数据库连接
NEFORCE_NODISCARD bool connected() const noexcept override
检查连接是否已建立
NEFORCE_NODISCARD string_view get_error() const noexcept override
获取最后错误信息