mysql的常用操作的封装
1、概述:
为了把繁琐的操作简化成简单的类,设计了2个类用来封装了mysql的常用操作,以便使用者可以方便地使用。
2、组成
1)数据库操作类CDatabaseConnect
2)SQL对象类CSqlStatement
3、类的头文件代码
#include <winsock.h>
#include "mysql.h"
#include <string>
using namespace std;
//MYSQL的返回码类型
#define MYSQL_OK
0
#define MYSQL_FALSE
!(MYSQL_OK)
#define MYSQL_ERROR
1
//SQL的SQL语句类型
#define MYSQL_SQL_TYPE_INSERT
0
#define MYSQL_SQL_TYPE_QUERY
1
//字符串的大小
#define MYSQL_CHAR_SIZE
0xFF+1
#define MYSQL_STRING_SIZE
0xFF+1
#define MYSQL_VARCHAR_SIZE
0xFFFF+1
#define MYSQL_VAR_STRING_SIZE
0xFFFF+1
#define MYSQL_MEDIUMBLOB_SIZE
0xFFFFFF+1
#define MYSQL_LONGBLOB_SIZE
0xFFFFFFFF+1
//日志入口函数指针
typedef void(*PAddLogFunc)(const char *pszData);
//数据库连接参数
typedef struct tagSTConnectParam
{
char szUser[64+1];
//用户名称
char szPasswd[64+1];
//用户密码
char szHost[64+1];
//主机名称
char szDbName[64+1];
//数据库名称
char *pszSocket;
//socket
unsigned int nPort;
//端口号
unsigned long ucClientFlag;
//客户端标识
}STConnectParam, *PSTConnectParam;
//SQL预处理对象
class CSqlStatement
{
public:
CSqlStatement();
CSqlStatement(MYSQL* pDb);
virtual ~CSqlStatement();
private:
friend class CDatabaseConnect;
CSqlStatement(MYSQL* pDb, const char *pszSqlStatement);
public:
//行数
int GetRowCount(void);
//列数
int GetColumnCount(void);
//nPosIndex started by zero
//列名称
const char *GetColumnName(int nPosIndex);
//列ID
int GetColumnIndex(const char *pszColumnName);
//获取整型
int GetColumnValueInt(int nPosIndex);
//获取短字符串
const char *GetColumnValueVarChar(int nPosIndex);
//获取长字符串
const char *GetColumnValueString(int nPosIndex);
//获取字符串
const char *GetColumnValueBlob(int nPosIndex, int *pnLen);
//获取浮点型
double GetColumnValueDouble(int nPosIndex);
//绑定整型
bool BindInt(int nPosIndex, const int &nValue);
//绑定短字符串
bool BindChar(int nPosIndex, const char *pszValue);
//绑定长字符串
bool BindString(int nPosIndex, const char *pszValue);
//绑定字符串
bool BindBlob(int nPosIndex, const char *pszValue, int nBlobBytes);
//获取浮点型
bool BindDouble(int nPosIndex, const double &fValue);
//运行
bool Execute(void);
//下一行
bool NextRow(void);
//复位
bool Reset(void);
//写日志
int WriteDbLog(const char *pszMsg);
//设置SQL预处理对象
int SetSqlStatement(const char *pszSqlStatement);
private:
//初始化数据
bool InitData(void);
//释放数据
void FreeData(void);
private:
//日志函数接口
PAddLogFunc pAddLog;
MYSQL_STMT *m_pStmt;
MYSQL* m_pDb;
MYSQL_RES *m_pPrepareMetaResult;
MYSQL_BIND *m_pBind;
unsigned long *m_plStringLen;
my_bool *m_pbArray;
int *m_pnDataArray;
double *m_pfDataArray;
char **m_pszDataArray;
string m_strSql;
string m_strErrMsg;
int m_nRowCount;
int m_nColumnCount;
int m_nSqlType;
int m_nBindParamFlag;
};
typedef CSqlStatement *PCSqlStatement;
//数据库连接
class CDatabaseConnect
{
public:
CDatabaseConnect();
virtual ~CDatabaseConnect();
//打开
bool Open(PSTConnectParam pstParam);
//关闭
bool Close(void);
//获取MySQL对象指针
MYSQL *GetMySQL(void);
//获取指定表名称的记录个数
int GetTableRecordCount(const char *pszTabelName);
//写日志
int WriteDbLog(const char *pszMsg);
//运行SQL语句
bool DirectStatement(const char *pszSqlStatement);
//产生SQL预处理对象
CSqlStatement* SetSqlStatement(const char *pszSqlStatement);
//释放SQL对象
void ReleaseStatement(void);
//获取指定SQL语句的查询记录个数
int GetRecordCount(const char *szSql);
//事务
bool BeginTransaction(void);
bool CommitTransaction(void);
bool RollbackTransaction(void);
public:
MYSQL * m_pDb;
private:
PAddLogFunc pAddLog;
CSqlStatement *m_pSqlStatement;
string m_strDbName;
string m_strSql;
string m_strErrMsg;
};
mysql的常用操作的封装的更多相关文章
- DBA必备:MySQL数据库常用操作和技巧
DBA必备:MySQL数据库常用操作和技巧 2011-02-25 15:31 kaduo it168 字号:T | T MySQL数据库可以说是DBA们最常见和常用的数据库之一,为了方便大家使用,老M ...
- Linux下mysql的常用操作
Linux下mysql的常用操作: 显示数据库 show databases; 选择数据库 use 数据库名; 显示数据库中的表 show tables; 显示数据表的结构 describe 表名; ...
- ubuntu下安装mysql及常用操作
1.可通过ps -ef | grep mysql命令查看系统中是否有安装mysql 如果出现类似上述的页面,就证明是已经安装过了mysql,否则就是没有. 2.安装mysql 很简单,只需要键入如下命 ...
- 网站用户行为分析——在Ubuntu下安装MySQL及其常用操作
安装MySQL 使用以下命令即可进行mysql安装,注意安装前先更新一下软件源以获得最新版本: sudo apt-get update #更新软件源 sudo apt-get install mysq ...
- Linux下MySql数据库常用操作
1.显示数据库 show databases; 2.选择数据库 use 数据库名; 3.显示数据库中的表 show tables; 4.显示数据表的结构 describe 表名; 5.显示表中记录 S ...
- mysql之常用操作
1. 数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据.我们也可以将数 ...
- mysql的常用操作
基本操作 #1 操作文件夹(库) 增 create database db1 charset utf8; --指定格式为utf8 查 show databases; --查看所有的数据库 show c ...
- Mysql之常用操作(2)
Windows服务 -- 启动MySQL net start mysql -- 创建Windows服务 sc create mysql binPath= mysqld_bin_path(注意:等号与值 ...
- MySQL数据库常用操作和技巧
MySQL数据库可以说是DBA们最常见和常用的数据库之一,MySQL的广泛应用,也使更多的人加入到学习它的行列之中.下面是老MySQL DBA总结的MySQL数据库最常见和最常使用的一些经验和技巧,分 ...
随机推荐
- 话说GET与POST那点恩怨
看过很多人写GET和POST之间的区别,为什么这么多人关注它们呢?因为它们是最常用的两种HTTP方法,之间有很多相同之处,也存在非常大的不同.首先了解一下HTTP方法: 什么是HTTP? 超文 ...
- 【剑指offer】替换字符串中的空格
转载请注明出处:http://blog.csdn.net/ns_code/article/details/25002199 剑指offer上的第四道题目,在九度OJ上測试通过,但还是有些问题.由于是用 ...
- 给定N个整数集合是否存在两个其和刚好为指定常数的元素
又一次学习一遍<算法导论>,看到了这个问题: 描写叙述一个执行时间为O(nlgn)的算法,使之能在给定一个由n个整数构成的集合S和还有一个整数 X 时,推断出S中是否存在有两个其和刚好等于 ...
- 黑马程序猿 IO流 ByteArrayInputStream与ByteArrayOutputStream
---------------------- ASP.Net+Unity开发..Net培训.期待与您交流! ---------------------- package cn.itcast.IO; i ...
- Ubuntu14.04配置arm-linux-gcc 4.4.3交叉编译环境
首先下载交叉编译:不多说,直接贴地址了 http://arm9download.cncncn.com/mini2440/linux/arm-linux-gcc-4.4.3-20100728.tar.g ...
- UVALive 4119 Always an integer (差分数列,模拟)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Always an integer Time Limit:3000MS M ...
- 控制点:ControlPoint
位于control:Points面板下,kitControl面板的ControlPallette中也存在控制点. 控制点是什么呢?一个数据值.一个传感器的值.比如,温度值,风速值,压力值,光照值,开关 ...
- mysql install
./scripts/mysql_install_db --user=mahao01 --basedir=/home/mahao01/local/mysql --datadir=/home/mahao0 ...
- 从Ecipse中导出程序至apk
若未有数字证书: 1. 2. 3. 4. 5. 若已有数字证书: 上面的后3步改为
- 轻松实现HTML5时钟(分享下自己对canvas的理解,原来没你想像的那么难哦)
Hey,guys! 让我们一起用HTML5实现一下简易时钟吧! 接触canvas时, 我突然有一种非常熟悉的感觉------canvas的部分的功能其实和Photoshop中的 钢笔工具 是一样的.所 ...