看过很多C或是C++操作MySQL数据库的文章,大部分太吃力了,甚至有一部分根本没有很好的组织文字,初学者比较难以接受,即使是C++或是C高手也是比较难看懂。写这篇文章的目的不是别的,就一个,告诉您用MySQL的C API直接操作MySQL数据,并做了比较高效的封装,可以帮助开发人员大幅度提高采用MySQL的C API操作MySQL数据库的效率。
直接进入主题:
 
准备工作我就不介绍了,请参考上一篇博客:http://www.cnblogs.com/mlgjb/p/8798361.html
 
在工程建立添加以下两个文件:
第一个文件头文件:VspdCTOMySQL.h
/****************************MYSQL IN C*******************************/
/*************************2007 -03 -07 *******************************/
/*************************李克喜**************************************/ #include <stdio.h>
#include <string>
#include <afxsock.h>
#include "mysql.h"
using namespace std;
class VspdCToMySQL
{
public: //变量
MYSQL mysql; /*
构造函数和稀构函数
*/
VspdCToMySQL();
~VspdCToMySQL(); /*
主要的功能:
初始化数据库
连接数据库
设置字符集 入口参数:
host :MYSQL服务器IP
port:数据库端口
Db:数据库名称
user:数据库用户
passwd:数据库用户的密码
charset:希望使用的字符集
Msg:返回的消息,包括错误消息 出口参数:
int :0表示成功;1表示失败
*/
int ConnMySQL(char *host,char * port,char * Db,char * user,char* passwd,char * charset,char * Msg); /*
主要的功能:
查询数据 入口参数:
SQL:查询的SQL语句
Cnum:查询的列数
Msg:返回的消息,包括错误消息 出口参数:
string 准备放置返回的数据,多条记录则用0x06隔开,多个栏位用0x05隔开
如果 返回的长度= 0,责表示舞结果
*/
string SelectData(char * SQL,int Cnum ,char * Msg); /*
主要功能:
插入数据 入口参数
SQL:查询的SQL语句
Msg:返回的消息,包括错误消息 出口参数:
int :0表示成功;1表示失败
*/
int InsertData(char * SQL,char * Msg); /*
主要功能:
修改数据 入口参数
SQL:查询的SQL语句
Msg:返回的消息,包括错误消息 出口参数:
int :0表示成功;1表示失败
*/
int UpdateData(char * SQL,char * Msg); /*
主要功能:
删除数据 入口参数
SQL:查询的SQL语句
Msg:返回的消息,包括错误消息 出口参数:
int :0表示成功;1表示失败
*/
int DeleteData(char * SQL,char * Msg); /*
主要功能:
关闭数据库连接
*/
void CloseMySQLConn(); };
 
 
第二个文件实现文件:VspdCTOMySQL.cpp
/****************************MYSQL IN C*******************************/
/*************************2007 -03 -07 *******************************/
/*************************李克喜**************************************/ #include "stdafx.h"
#include "VspdCTOMySQL.h" VspdCToMySQL::VspdCToMySQL()
{
} VspdCToMySQL::~VspdCToMySQL()
{
} //初始化数据
int VspdCToMySQL::ConnMySQL(char *host,char * port ,char * Db,char * user,char* passwd,char * charset,char * Msg)
{
if( mysql_init(&mysql) == NULL )
{
Msg = "inital mysql handle error";
return ;
} if (mysql_real_connect(&mysql,host,user,passwd,Db,,NULL,) == NULL)
{
Msg = "Failed to connect to database: Error";
return ;
} if(mysql_set_character_set(&mysql,"GBK") != )
{
Msg = "mysql_set_character_set Error";
return ;
}
return ;
} //查询数据
string VspdCToMySQL::SelectData(char * SQL,int Cnum,char * Msg)
{
MYSQL_ROW m_row;
MYSQL_RES *m_res;
char sql[];
sprintf(sql,SQL);
int rnum = ;
char rg = 0x06;//行隔开
char cg = {0x05};//字段隔开 if(mysql_query(&mysql,sql) != )
{
Msg = "select ps_info Error";
return "";
}
m_res = mysql_store_result(&mysql); if(m_res==NULL)
{
Msg = "select username Error";
return "";
}
string str("");
while(m_row = mysql_fetch_row(m_res))
{
for(int i = ;i < Cnum;i++)
{
str += m_row[i];
str += rg;
}
str += rg;
rnum++;
} mysql_free_result(m_res); return str;
}
 
 
//插入数据
int VspdCToMySQL::InsertData(char * SQL,char * Msg)
{
char sql[];
sprintf(sql,SQL);
if(mysql_query(&mysql,sql) != )
{
Msg = "Insert Data Error";
return ;
}
return ;
}
 
//更新数据
int VspdCToMySQL::UpdateData(char * SQL,char * Msg)
{
char sql[];
sprintf(sql,SQL);
if(mysql_query(&mysql,sql) != )
{
Msg = "Update Data Error";
return ;
}
return ;
}
//删除数据
int VspdCToMySQL::DeleteData(char * SQL,char * Msg)
{
char sql[];
sprintf(sql,SQL);
if(mysql_query(&mysql,sql) != )
{
Msg = "Delete Data error";
return ;
}
return ;
}
//关闭数据库连接
void VspdCToMySQL::CloseMySQLConn()
{
mysql_close(&mysql);
}
 
 
在main函数,(如果是其他工程级不是main了,可能是一个按钮里面的代码块)添加      一些代码,添加之后如下
#include "stdafx.h"
#include "VspdCTOMySQL.h" int main(int argc, char* argv[])
{
char* host="MYSQL服务器IP";
char* user="root";
char* port ="";
char* passwd="用户密码";
char* dbname="数据库名称";
char* charset = "GBK";//支持中文
char* Msg = "";//消息变量
//初始化
VspdCToMySQL * vspdctomysql = new VspdCToMySQL;
if(vspdctomysql->ConnMySQL(host,port,dbname,user,passwd,charset,Msg) == )
printf("连接成功/r/n");
else
printf(Msg); //查询
char * SQL = "SELECT ids,username,passwd,address FROM vcaccesstest";
string str = vspdctomysql->SelectData(SQL,,Msg);
if( str.length() > )
{
printf("查询成功/r/n");
printf(str.data());
printf("/r/n");
}
else
{
printf(Msg);
}
//插入
SQL = "insert into vcaccesstest(ids,username,passwd,address) values(4,'我的','123210','测试地址')";
if(vspdctomysql->InsertData(SQL,Msg) == )
printf("插入成功/r/n");
//更新
SQL = "update vcaccesstest set username = '修改了',passwd='2345' where ids = 3 ";
if(vspdctomysql->UpdateData(SQL,Msg) == )
printf("更新成功/r/n");
//删除
SQL = "delete from vcaccesstest where ids = 3 ";
if(vspdctomysql->DeleteData(SQL,Msg) == )
printf("删除成功/r/n"); vspdctomysql->CloseMySQLConn(); return ;
}
 
数据库表确认表存在,(程序中的表和字段是我的数据库里面的内容,你要自己搞定你的SQL语句了,你可以看main函数里面的SQL变量的内容。
补充:
在上面的例子中sql语句是对常量进行操作的,比较简单,但是如果对变量进行操作就比较麻烦了
基本思路为:1、将这些变量用字符串的形式连接起来,如果里面含有数值变量还要将先转换为字符串的形式。2、再考虑逗号与单引号的问题(在sql语句中,字符串需要用单引号括起来)。
在C语言中,将数字转换成字符串和连接字符串这两项功能都可以用sprintf()函数实现。
 
编译,运行,一切ok。
总结,你要做的事情很少了,两个主要的文件写好了,你看例子调用即可,其他MySQL的库文件和附加文件别人也为您准备好了,移植到其他系统也是很简单的,比如移植到Linux和Unix下也是很简单的,VspdCTOMySQL.h和VspdCTOMySQL.cpp基本上是采用标准的C++编写的,在别的系统可能需要做少量修改即可。

原文传送门:https://blog.csdn.net/jemlee2002/article/details/1523164

c++读写MySQL的更多相关文章

  1. Hadoop 中利用 mapreduce 读写 mysql 数据

    Hadoop 中利用 mapreduce 读写 mysql 数据   有时候我们在项目中会遇到输入结果集很大,但是输出结果很小,比如一些 pv.uv 数据,然后为了实时查询的需求,或者一些 OLAP ...

  2. shell中读写mysql数据库

    本文介绍了如何在shell中读写mysql数据库.主要介绍了如何在shell 中连接mysql数据库,如何在shell中创建数据库,创建表,插入csv文件,读取mysql数据库,导出mysql数据库为 ...

  3. R语言使用RMySQL连接及读写Mysql数据库 测试通过

    R语言使用RMySQL连接及读写Mysql数据库 简单说下安装过程,一般不会有问题,重点是RMySQL的使用方式. 系统环境说明 Redhat系统:Linux 460-42.6.32-431.29.2 ...

  4. JDBC读写MySQL的大字段数据

    JDBC读写MySQL的大字段数据   不管你是新手还是老手,大字段数据的操作常常令你感到很头痛.因为大字段有些特殊,不同数据库处理的方式不一样,大字段的操作常常是以流的方式 来处理的.而非一般的字段 ...

  5. spark读写mysql

    spark读写mysql除官网例子外还要指定驱动名称 travels.write .mode(SaveMode.Overwrite) .format("jdbc") .option ...

  6. kettle大数据量读写mysql性能优化

       修改kettleDB连接设置 1. 增加批量写的速度:useServerPrepStmts=false  rewriteBatchedStatements=true  useCompressio ...

  7. R语言使用RMySQL连接及读写Mysql数据库

    简单说下安装过程,一般不会有问题,重点是RMySQL的使用方式. 系统环境说明 Redhat系统:Linux 460-42.6.32-431.29.2.el6.x86_64 系统编码:LANG=zh_ ...

  8. Spark学习笔记——读写MySQL

    1.使用Spark读取MySQL中某个表中的信息 build.sbt文件 name := "spark-hbase" version := "1.0" scal ...

  9. C++ 读写MySQL经典 (转载)

    from: http://blog.csdn.net/jemlee2002/article/details/1523164   看过很多C或是C++操作MySQL数据库的文章,大部分太吃力了,甚至有一 ...

随机推荐

  1. Python 列表嵌套多种实现方式

    #coding=utf-8 list=[] for i in range(1,101): list.append(i) # print(list) tempList=[] newList=[] whi ...

  2. 算法题丨Two Sum

    描述 Given an array of integers, return indices of the two numbers such that they add up to a specific ...

  3. C语言学习之弹跳小球

    重新回过头来看了一遍C语言,才发现我自己的无知,C语言其实好强大,我之前学的不过是一点C语法和做几个数学题.正好3月份的考试要考C语言,重新学一遍,先是在中国大学mooc上把翁恺老师的C语言刷了一遍, ...

  4. 为什么java中用枚举实现单例模式会更好

    代码简洁 这是迄今为止最大的优点,如果你曾经在Java5之前写过单例模式代码,那么你会知道即使是使用双检锁你有时候也会返回不止一个实例对象.虽然这种问题通过改善java内存模型和使用volatile变 ...

  5. R语言-离职率分析

    案例:员工流失是困扰企业的关键因素之一,在这次的分析中我将分析以下内容: 对一些重要变量进行可视化及探索分析,收入,晋升,满意度,绩效,是否加班等方面进行单变量分析 分析员工流失的因素,探索各个变量的 ...

  6. Docker学习笔记 - 在运行中的容器内启动新进程

    docker psdoker top dc1 # 容器情况# 在运行中的容器内启动新进程docker exec [-d] [-i] [-t] 容器名 [command] [args]docker ex ...

  7. Go语言的核心Routine-Channel

    前言 Go语言通过routine,提供了并发编程的支持. Routine特性 (1) goroutine是Go语言运行库的功能,不是操作系统提供的功能,goroutine不是用线程实现的. 例:启动一 ...

  8. Mybatis自动生成Xml文件,针对字段类型为text等会默认产生XXXXWithBlobs的方法问题

    默认情况下产生的Mapper.xml里面存在: 需要修改generatorConfiguration.xml,里面的table加属性,如: <table domainObjectName=&qu ...

  9. .NET反编译工具:de4dot

    de4dot是一款C#编写的基于GPLv3协议的一个开源的.net反混淆脱壳工具,是目前.net下非常不错的一款反编译工具. 支持如下混淆器: Agile.NET (aka CliSecure) Ba ...

  10. linux添加超级用户

    创建super账号 useradd testuser 创建用户testuser passwd testuser 给已创建的用户testuser设置密码 如果需要让此用户有root权限,执行命令: ro ...