用C++封装MySQL的API的教程_MySQL
程序员文章站
2022-05-28 17:55:04
...
其实相信每个和mysql打过交道的程序员都应该会尝试去封装一套mysql的接口,这一次的封装已经记不清是我第几次了,但是每一次我希望都能做的比上次更好,更容易使用。
先来说一下这次的封装,遵守了几个原则,其中部分思想是从python借鉴过来的:
1.简单
简单,意味着不为了微小的效率提升,而去把接口搞的复杂。因为本身数据库存储效率的瓶颈并不是那一两次内存copy,代码中随处可以看到以这个为依据的设计。
2.低学习成本
使用一套新库通常意味着投入学习成本,而这次的封装并没有像django那样实现一套完整的模型系统,也没有做soci那样的语法分析器,我选择最简单易懂的方式:做sql语句拼接器,所以对习惯了使用原生mysql api的朋友,学习成本很低
3.模块化
代码实际包括了两个模块,一个是mysql client端的封装,一个是sql的拼接器,这两个模块是完全独立的,调用者可以任意组合或者独立使用。
4.尽量使用STL以及模板,简化代码编写
最大的特点就是大量使用了stringstream进行类型转化,减少了大量的重复代码。
OK,基于以上的简单介绍,我们先来看一下
一.mysql client端的封装:
class CMYSQLWrapper { /** * @brief 获取错误信息 * * @return 错误信息 */ char* GetErrMsg(); /** * @brief 连接MYSQL,已经支持了自动重连模式,即mysql server关闭链接会自动重连 * * @param ip IP * @param user 用户名 * @param pwd 密码(没有则传NULL) * @param db 库(没有则传NULL) * * @return 0 succ * else fail */ int Open(const char* ip,const char* user,const char* pwd,const char* strDb); /** * @brief 关闭链接并释放result */ void Close(); /** * @brief 执行SQL语句 * * @param strSql 执行语句 * @param result 执行结果 * * @return 0 succ * else fail */ int Query(const char* strSql); /** * @brief 针对Read(select)相关的的Query,可以支持blob了 * * @param strSql sql语句 * @param vecData rows * * @return 0 succ * else fail */ int Query(const char* strSql, vector
推荐阅读
-
CentOs7.x安装Mysql的详细教程
-
用Jena将本体文件存入MySQL数据库的实现方法
-
Windows(x86,64bit)升级MySQL 5.7.17免安装版的详细教程
-
Linux 安装JDK Tomcat MySQL的教程(使用Mac远程访问)
-
mysql用一个表更新另一个表的方法
-
MySQL5.7.20解压版安装和修改root密码的教程
-
Windows10 64位安装MySQL5.6.35的图文教程
-
Ubuntu18.04 安装mysql8.0.11的图文教程
-
用Python的Flask框架结合MySQL写一个内存监控程序
-
win10 下安装mysql服务器社区版本mysql 5.7.22 winx64的图文教程