资源简介
使用C++语言对MySQL数据库的基本操作进行了封装,基于面向对象思想,可以应用在简单的项目实战中,亲测可用哦,欢迎下载交流

代码片段和文件信息
#include“CSingleton.h“
#include
CSingleton * CSingleton::getInstance(void)
{
if (CSingleton::instance == NULL)
{
CSingleton::instance = new CSingleton();
}
return CSingleton::instance;
}
CSingleton::CSingleton()
{
mysql = mysql_init(NULL);
if (mysql==NULL)
{
EXIT_ERROR(“init error:“);
}
}
void CSingleton::connect(string host string user string passwd string database)
{
if (mysql_real_connect(mysql host.c_str() user.c_str() passwd.c_str()database.c_str() 0 NULL 0)==NULL)
{
cout << “Query Error:“ << mysql_error(mysql) << endl;
}
else
{
cout << “database connect success!“ << endl;
}
}
bool CSingleton::setTable(string sql)
{
//返回值:0表示正常,非0表示发生了错误
if (mysql_query(mysql sql.c_str()))
{
cout << “Query Error:“ << mysql_error(mysql) << endl;
return false;
}
return true;
}
bool CSingleton::delTable(const char * tablename)
{
char strsql[128];
sprintf(strsql “drop table %s;“ tablename);
if (mysql_query(mysql strsql))
{
cout << “Query Error:“ << mysql_error(mysql) << endl;
return false;
}
return true;
}
bool CSingleton::insertValues(const char * tablename char values[])
{
char sql[128] = ““;
int i = 0;
char *str = NULL;
////每一个表最多有10列属性
char *valuesbuff[10] = { NULL };
str = strtok(values ““);
while (str != NULL)
{
valuesbuff[i++] = str;
str = strtok(NULL ““);
}
switch (i)
{
case 1:
sprintf(sql “insert into %s values(‘%s‘)“ tablename valuesbuff[0]);
break;
case 2:
sprintf(sql “insert into %s values(‘%s‘‘%s‘)“ tablename valuesbuff[0] valuesbuff[1]);
break;
case 3:
sprintf(sql “insert into %s values(‘%s‘‘%s‘‘%s‘)“ tablename valuesbuff[0] valuesbuff[1] valuesbuff[2]);
break;
case 4:
sprintf(sql “insert into %s values(‘%s‘‘%s‘‘%s‘‘%s‘)“ tablename valuesbuff[0] valuesbuff[1] valuesbuff[2] valuesbuff[3]);
break;
case 5:
sprintf(sql “insert into %s values(‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘)“ tablename valuesbuff[0] valuesbuff[1] valuesbuff[2] valuesbuff[3] valuesbuff[4]);
break;
case 6:
sprintf(sql “insert into %s values(‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘)“ tablename valuesbuff[0] valuesbuff[1] valuesbuff[2] valuesbuff[3] valuesbuff[4] valuesbuff[5]);
break;
case 7:
sprintf(sql “insert into %s values(‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘,‘%s‘)“ tablename valuesbuff[0] valuesbuff[1] valuesbuff[2] valuesbuff[3] valuesbuff[4] valuesbuff[5] valuesbuff[6]);
break;
case 8:
sprintf(sql “insert into %s values(‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘,‘%s‘‘%s‘)“ tablename valuesbuff[0] valuesbuff[1] valuesbuff[2] valuesbuff[3] valuesbuff[4] valuesbuff[5] valuesbuff[6] valuesbuff[7]);
break;
case 9:
sprintf(sql “insert into %s values(‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘‘%s‘,‘%s‘‘%s‘,‘%s‘)“ tablename valuesbuff[0] valuesbuff[1] valuesbuff[2] valuesbuff[3] valuesbuff[4] valuesbuff[5] valuesbuff[6]valuesbuff[7] valuesbuff[8]);
br
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 5089 2020-05-15 19:20 mysql封装\CSingleton.cpp
文件 1613 2020-05-15 18:52 mysql封装\CSingleton.h
文件 1028 2020-05-15 19:21 mysql封装\main.cpp
目录 0 2020-05-15 20:07 mysql封装\
- 上一篇:简易电子琴_proteus.rar
- 下一篇:学生作业完成情况管理系统C++含报告
相关资源
- C++中头文件与源文件的作用详解
- C++多线程网络编程Socket
- VC++ 多线程文件读写操作
- 利用C++哈希表的方法实现电话号码查
- 移木块游戏,可以自编自玩,vc6.0编写
- C++纯文字DOS超小RPG游戏
- LINUX下命令行界面的C语言细胞游戏
- 尚观培训linux许巍老师关于c语言的课
- VC++MFC小游戏实例教程(实例)+MFC类库
- 连铸温度场计算程序(C++)
- 6自由度机器人运动学正反解C++程序
- Em算法(使用C++编写)
- libstdc++-4.4.7-4.el6.i686.rpm
- VC++实现CMD命令执行与获得返回信息
- 白话C++(全)
- C++标准库第1、2
- 大数类c++大数类
- C++语言编写串口调试助手
- c++素数筛选法
- 《Linux程序设计》第四版pdf高清电子版
- C++ mqtt 用法
- 商品库存管理系统 C++ MFC
- c++ 多功能计算器
- C++17 In Detail
- linux 0.11内核代码
- linux ac108多麦方案驱动(ac108.c)
- 共享内存 读写
- 简易web服务器的设计与实现
- 《LINUX C编程从初学到精通》光盘源码
- 嵌入式QtC++编程课件
评论
共有 条评论