CMySQLMgr.h:

#ifndef _CMYSQLMGR_H_
#define _CMYSQLMGR_H_ #include <iostream>
#include "mysql.h" using namespace std; class CMySQLMgr
{
public:
CMySQLMgr();
~CMySQLMgr(); bool Connect(const char * sHost, const char * sUser, const char * sPwd, const char * sDbName, const char * sPort);
void CloseConnect(); bool excute(const char * sQuery); MYSQL * GetpMysql(); private:
MYSQL * m_pMysql;
}; #endif

  

CMySQLMgr.cpp:

#include "CMySQLMgr.h"

CMySQLMgr::CMySQLMgr()
{
m_pMysql = NULL;
} CMySQLMgr::~CMySQLMgr()
{ } bool CMySQLMgr::Connect( const char * sHost, const char * sUser, const char * sPwd, const char * sDbName, const char * sPort )
{
bool bReturn = true;
do
{
CloseConnect();
m_pMysql = mysql_init(NULL);
if (!m_pMysql)
{
bReturn = false;
//can write log
break;
} //参数设置
char optvalue = 6;
mysql_options(m_pMysql, MYSQL_OPT_CONNECT_TIMEOUT, (char*)&optvalue);
optvalue = 1;
mysql_options(m_pMysql, MYSQL_OPT_RECONNECT, (char*)&optvalue);
optvalue = 2;
mysql_options(m_pMysql, MYSQL_OPT_READ_TIMEOUT, (char*)&optvalue); if (!mysql_real_connect(m_pMysql, sHost, sUser, sPwd, sDbName, atoi(sPort), NULL, 0) )
{
bReturn = false;
//can write log
cout << "mysql error:" << mysql_error(m_pMysql);
break;
}
} while (0); return bReturn;
} void CMySQLMgr::CloseConnect()
{
if (m_pMysql)
{
mysql_close(m_pMysql);
}
} bool CMySQLMgr::excute( const char * sQuery )
{
bool bReturn = true;
try
{
if (0 != mysql_query(m_pMysql, sQuery))
{
bReturn = false;
cout << "mysql error:" << mysql_error(m_pMysql);
//can write log
}
}
catch (std::exception &e)
{
cout << "exception:" << e.what() << endl;
}
catch (...)
{
cout << "Unknown exception." << endl;
} return bReturn;
} MYSQL * CMySQLMgr::GetpMysql()
{
if (m_pMysql)
{
return m_pMysql;
}
}

main.cpp:

#include <iostream>
#include <stdio.h>
#include "CMySQLMgr.h"
using namespace std; int main()
{
CMySQLMgr mysql;
bool bRet = mysql.Connect("172.16.8.110", "root", "123456", "scistock", "3306"); char buf[1024*2] = {0}; const char * sSql = "select * from calcgsdataflash where gscode = 'ZTJB' ";
bRet = mysql.excute(sSql);
if (!bRet)
{
cout << "sSql:" << sSql << " excute error" << endl;
} MYSQL_RES *res;
MYSQL_ROW row;
MYSQL_FIELD *fields;
res = mysql_store_result(mysql.GetpMysql());
if (res)
{
int nFields = mysql_num_fields(res);
fields = mysql_fetch_fields(res); while ((row = mysql_fetch_row(res)))
{
string gpcode;
int ymd = 0;
int hms = 0;
float f10 = 0;
for (int j = 0; j < nFields; j++)
{
if (row[j])
{
if (strncmp(fields[j].name, "gpcode", strlen("gpcode")) == 0)
{
gpcode = row[j];
}
else if (strncmp(fields[j].name, "ymd", strlen("ymd")) == 0)
{
ymd = atoi(row[j]);
}
else if (strncmp(fields[j].name, "hms", strlen("hms")) == 0)
{
hms = atoi(row[j]);
int hour = hms / 3600;
int minute = hms / 60 % 60;
int second = hms % 60;
hms = hour * 10000 + minute * 100 + second;
}
else if (strncmp(fields[j].name, "f10", strlen("f10")) == 0)
{
f10 = atoi(row[j]);
}
}
} sprintf(buf, "update calcgsdataflash set hms = %d WHERE gscode = 'ZTJB' AND ymd = %d AND gpcode = '%s' AND f10 = %f", hms, ymd, gpcode.c_str(), f10);
cout << "sSql:" << buf << endl;
bool bRet = mysql.excute(buf);
if (!bRet)
{
cout << "sSql:" << buf << " excute error" << endl;
}
}
mysql_free_result(res);
}
mysql.CloseConnect();
return 0;
}

 

MySQL官网(https://www.mysql.com/

Api 连接库下载地址(https://dev.mysql.com/downloads/connector/c/

Windows :

  1.从官网下载Windows的对应版本的连接库。

    

  2.解压 1 中下载的压缩包

     

  3.vs 项目中加入 2 中库文件目录下的 include文件夹、lib文件夹下的 libmysql.lib。

    (将 libmysql.dll 拷贝至可执行程序目录下)

    项目配置(Debug or Release、Win32 or x64)要与下载的库版本保持一致。

    若 Release 模式下需要断点调试,参见:http://www.cnblogs.com/SZxiaochun/p/6928854.html

    

Linux:

  1.从官网下载 Linux 对应版本的连接库

    

  2.安装库

    1.如果下载的是压缩包

      

      解压之后

        sudo cp -r include/ /usr/include/mysql/

        sudo cp -r lib/ /usr/lib64/mysql/

    2.如果下载的是 .rpm 文件,直接安装

        sudo rpm -ivh mysql-connector-c-devel-6.1.11-1.el7.x86_64.rpm (rpm 命令的用法参见:http://www.cnblogs.com/SZxiaochun/p/7718606.html

    3.makefile 引用安装的库

      1.静态库 libmysqlclient.a

         

      2.动态库 libmysqlclient.so (如果安装之后没有 libmysqlclient.so ,只有 libmysqlclient.so.18.0.0,就链接一下 ln libmysqlclient.so.18.0.0 libmysqlclient.so ,或者重命名也行)

         

批量插入:

//InnoDB表引擎下关闭mysql自动事务提交可以大大提高数据插入的效率,这是因为如果需要插入1000条数据,    mysql会自动发起(提交)1000次的数据写入请求,如果把autocommit关闭掉,通过程序来控制,只要一 次commit就可以搞定。

#define WRITE_ONCE_COUNT  1000  //设一个宏,表示多少条数据提交一次

int count = 0;            //设一个计数值

mysql_autocommit(mysql,0);//关闭自动提交

sprintf(buf,"insert into dxjl_infobase(Date,gpcode,Type) values(%d,'%s',%d)",nDate,codes,1);

ASC2UTF8(buf,buf,sizeof(buf));//转编码,将ASC转为UTF8  以便数据库可以识别sql语句

int iSuccess = mysql_query(mysql,buf);
if(iSuccess !=0)
{
printf("mysql_query:%s\r\n",mysql_error(mysql));
}
else
{
count ++;
}
if(WRITE_ONCE_COUNT == count)//每WRITE_ONCE_COUNT条数据提交一次
{
mysql_commit(mysql);
count = 0;
}
出了循环之后加个判断,避免最后一次循环数据未达到WRITE_ONCE_COUNT,无法commit提交写库:
if(0 < count)
{
mysql_commit(mysql);
}

autocommit是事务,==1时是立即提交,==0之后遇到commit或rollback才提交。

C API 连接MySQL及批量插入的更多相关文章

  1. jmeter连接mysql数据库批量插入数据

    前提工作: 1.在jmeter官网下载jmeter包(官网地址:https://jmeter.apache.org/).此外还需下载mysql驱动包,如:mysql-connector-java-5. ...

  2. Mysql 如何批量插入百万行测试数据

    Mysql 如何批量插入百万行测试数据

  3. Mysql优化批量插入数据

    最近为了测试项目,需要在Mysql中插入百万级测试数据,于是用到了批量插入,自己写了个简单的Spring Cloud项目. 开始时执行效率很慢,大概100条/秒,批次的大小也试过1000,2000,5 ...

  4. php如何在mysql里批量插入数据

    假如说我有这样一个表,我想往这个表里面插入大量数据 CREATE TABLE IF NOT EXISTS `user_info` ( `id` int(11) NOT NULL AUTO_INCREM ...

  5. mysql+ibatis 批量插入

    述:相比oracle批量插入,mysql批量插入就简单的多了,mysql支持values后面跟多条数据,进行批量插入,并且主键可以自增,不像oracle会遇到序列问题. 1.建表 CREATE TAB ...

  6. C Mysql API连接Mysql

    最近都在查看MYsql C API文档,也遇到了很多问题,下面来简单的做一个总结. mysql多线程问题 mysql多线程处理不好,经常会发生coredump,见使用Mysql出core一文. 单线程 ...

  7. Mybatis 针对ORACLE和MYSQL的批量插入与多参数批量删除

    今天利用Mybatis的<for each>标签做oracle的批量插入数据时,发现和MySQL数据库有区别.在此记录下,以防之后再踩坑. 一.批量插入: 1.controller: /* ...

  8. 向mysql中批量插入数据的性能分析

    MYSQL批量插入数据库实现语句性能分析 假定我们的表结构如下 代码如下   CREATE TABLE example (example_id INT NOT NULL,name VARCHAR( 5 ...

  9. mysql 循环批量插入

    背景 前几天在MySql上做分页时,看到有博文说使用 limit 0,10 方式分页会有丢数据问题,有人又说不会,于是想自己测试一下.测试时没有数据,便安装了一个MySql,建了张表,在建了个whil ...

随机推荐

  1. centos部署supervisor

    #!/bin/bash yum -y install python-setuptools ping pypi.python.org -c 4 >/dev/null 2>&1 eas ...

  2. php DES加密或者解密

    function pkcs5_pad ($text, $blocksize) { //加密时的字节填充,保持和java 一致 $pad = $blocksize - (strlen($text) % ...

  3. 【备用】SQL SERVER存储过程执行速度慢的问题

    今天看到了但是暂时没有时间研究,先留着备用(Parameter Sniffing) http://blog.csdn.net/emili/article/details/2192081 http:// ...

  4. ubuntu的交换分区和系统休眠

    因为休眠功能在部分计算机上不能正常工作,所以自16.04后,ubuntu不在默认开启休眠功能. 要开启休眠功能需要如下条件. 1.要有交换分区(swap). 2.交换分区的容量至少要和实际内存一样大, ...

  5. nginx中配置404错误页面的教程

    什么是404页面如果网站出了问题,或者用户试图访问一个并不存在的页面时,此时服务器会返回代码为404的错误信息,此时对应页面就是404页面.404页面的默认内容和具体的服务器有关.如果后台用的是NGI ...

  6. 百度Android在线语音识别SDK用法

    百度Android语音识别SDK分在线与离线两种,这篇文章介绍在线SDK的用法. 在线SDK是以JAR包和动态链接库形式公布和使用,能够从百度开放云平台站点中下载SDK及使用说明文档. title=d ...

  7. ny71 独木舟的旅行

    独木舟上的旅行时间限制:3000 ms  |  内存限制:65535 KB难度:2描述进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能乘坐两个人,且乘客的总重量不能 ...

  8. css reset.css

    /* http://meyerweb.com/eric/tools/css/reset/ v2.0 | 20110126 License: none (public domain) */ html, ...

  9. java.util.logging.Logger日志生成过程浅析 (转)

    http://www.tuicool.com/articles/vy6Zrye ****************************************** java.util.logging ...

  10. LeetCode: Roman to Integer 解题报告

    Roman to IntegerGiven a roman numeral, convert it to an integer. Input is guaranteed to be within th ...