c++读写MySQL
/****************************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(); };
/****************************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);
}
#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 ;
}
原文传送门:https://blog.csdn.net/jemlee2002/article/details/1523164
c++读写MySQL的更多相关文章
- Hadoop 中利用 mapreduce 读写 mysql 数据
Hadoop 中利用 mapreduce 读写 mysql 数据 有时候我们在项目中会遇到输入结果集很大,但是输出结果很小,比如一些 pv.uv 数据,然后为了实时查询的需求,或者一些 OLAP ...
- shell中读写mysql数据库
本文介绍了如何在shell中读写mysql数据库.主要介绍了如何在shell 中连接mysql数据库,如何在shell中创建数据库,创建表,插入csv文件,读取mysql数据库,导出mysql数据库为 ...
- R语言使用RMySQL连接及读写Mysql数据库 测试通过
R语言使用RMySQL连接及读写Mysql数据库 简单说下安装过程,一般不会有问题,重点是RMySQL的使用方式. 系统环境说明 Redhat系统:Linux 460-42.6.32-431.29.2 ...
- JDBC读写MySQL的大字段数据
JDBC读写MySQL的大字段数据 不管你是新手还是老手,大字段数据的操作常常令你感到很头痛.因为大字段有些特殊,不同数据库处理的方式不一样,大字段的操作常常是以流的方式 来处理的.而非一般的字段 ...
- spark读写mysql
spark读写mysql除官网例子外还要指定驱动名称 travels.write .mode(SaveMode.Overwrite) .format("jdbc") .option ...
- kettle大数据量读写mysql性能优化
修改kettleDB连接设置 1. 增加批量写的速度:useServerPrepStmts=false rewriteBatchedStatements=true useCompressio ...
- R语言使用RMySQL连接及读写Mysql数据库
简单说下安装过程,一般不会有问题,重点是RMySQL的使用方式. 系统环境说明 Redhat系统:Linux 460-42.6.32-431.29.2.el6.x86_64 系统编码:LANG=zh_ ...
- Spark学习笔记——读写MySQL
1.使用Spark读取MySQL中某个表中的信息 build.sbt文件 name := "spark-hbase" version := "1.0" scal ...
- C++ 读写MySQL经典 (转载)
from: http://blog.csdn.net/jemlee2002/article/details/1523164 看过很多C或是C++操作MySQL数据库的文章,大部分太吃力了,甚至有一 ...
随机推荐
- 看到一个对CAP简单的解释
一个分布式系统里面,节点组成的网络本来应该是连通的.然而可能因为一些故障,使得有些节点之间不连通了,整个网络就分成了几块区域.数据就散布在了这些不连通的区域中.这就叫分区.当你一个数据项只在一个节点中 ...
- IIS 配置 FTP 网站
在 服务器管理器 的 Web服务器IIS 上安装 FTP 服务 在 IIS管理器 添加FTP网站 配置防火墙规则 说明:服务器环境是Windows Server 2008 R2,IIS7.5. 1. ...
- Linq GroupBy
//Linq //var result = from p in personList // group p by p.Id // into grouped // select new { Id = g ...
- 帧动画的创建方式 - 纯Java代码方式
废话不多说,先看东西 帧动画的创建方式主要以下2种: * 用xml创建动画: * 纯Java代码创建动画: 本文内容主要关注 纯java代码创建帧动画 的方式: 用xml创建帧动画:http:// ...
- redis入门(15)redis的数据备份和恢复
redis入门(15)redis的数据备份和恢复
- kafka之zookeeper 节点
1.zookeeper 节点 kafka 在 zookeeper 中的存储结构如下图所示:
- 百度地图api的用法
功能: 1.点击"江干区",地图自动定位到该区域,并且该区域出现overlay(红色) 2.点击"派出所"."社区"级别时,地图也自动定位同 ...
- Python入门之三元表达式\列表推导式\生成器表达式\递归匿名函数\内置函数
本章目录: 一.三元表达式.列表推导式.生成器表达式 二.递归调用和二分法 三.匿名函数 四.内置函数 ================================================ ...
- phpstorm 快捷键高效助手扩展 常用快捷键收集整理 2018-04-12 16:42:10
声明: 本文属于原创,未经博主许可,禁止任何形式转载! phpstorm 快捷键整理收集 以及高效复用代码快捷键扩展 常规快捷键大全请结合参考2篇博客: https://blog.csdn.net/y ...
- [转]pycharm常用快捷键及设置
PyCharm3.0默认快捷键(翻译的) PyCharm Default Keymap 1.编辑(Editing) Ctrl + Space 基本的代码完成(类.方法.属性)Ctrl + Alt ...