我下载最新的connector C++ 1.1.6  貌似 库里还没有批量插入数据的接口  不像JDBC 有addbatch() 这个接口
请问我在C++ 下 要大量数据批量导入到数据库里要怎么操作 ,我的情况是程序在运行中会产生大量数据要插入到数据库里
所以我使用批量导入来提升效率。

解决方案 »

  1.   

    楼主你好
            通常来说C++操作MySQL的时候,往Mysql中插入10000条简单数据,速度非常缓慢,居然要5分钟左右,
    而打开事务的话,一秒不到就搞定了!
    具体实现代码如下:
    #include <iostream>
    #include <winsock2.h>
    #include <string>
     
    #include "mysql.h"
     
    #pragma comment(lib, "libmysql.lib");
     
    using namespace std;
     
    int main()
    {
     MYSQL mysql;
     mysql_init(&mysql); // 初始化
     
     MYSQL *ConnStatus = mysql_real_connect(&mysql,"localhost","root","","sky",3306,0,0);
     if (ConnStatus == NULL)
     {
     // 连接失败
     int i = mysql_errno(&mysql);
     string strError= mysql_error(&mysql);
     cout <<"Error info: "<<strError<<endl;
     
     return 0;
     }
     
     
     cout<<"Mysql Connected..."<<endl;
      
     string strsql;
     MYSQL_RES *result=NULL; // 数据结果集
     
     // 插入操作
     strsql = "insert into t1 values(2,'lyb')";
     
     mysql_query(&mysql,"START TRANSACTION"); // 开启事务, 如果没有开启事务,那么效率会变得非常低下!
     
     for (int i=0; i<10000; i++)
     {
     mysql_query(&mysql,strsql.c_str());
     }
     
     mysql_query(&mysql,"COMMIT");   // 提交事务
     
     cout<<"insert end"<<endl;
     
      
     //释放结果集 关闭数据库
     mysql_free_result(result);
     mysql_close(&mysql);
     mysql_library_end();
     
     return 0;
    }