标签:insert char endTime int into bulk startTime mysql include
1.h1.cpp
#include <chrono> #include <iostream> #include <mysql/mysql.h> #include <sstream> #include <string.h> #include <uuid/uuid.h> using namespace std; static char *uuidValue = (char *)malloc(40); void mysqlClientDemo(); void mysqlClientInsert2(); void insertBulk3(int loops); char *getUuid() { uuid_t newUUID; uuid_generate(newUUID); uuid_unparse(newUUID, uuidValue); return uuidValue; } int main(int args, char **argv) { insertBulk3(atoi(argv[1])); } void insertBulk3(int loops) { try { MYSQL *conn, mysql; int state; mysql_init(&mysql); conn = mysql_real_connect(&mysql, "localhost", "root", "Root0001!", "myDB", 0, 0, 0); if (conn == NULL) { cout << mysql_error(&mysql) << endl; return; } stringstream ss; int64_t num = 0; int repeatedTimes = 1000000; chrono::time_point<chrono::system_clock> startTime; chrono::time_point<chrono::system_clock> endTime; for (int i = 0; i < loops; i++) { startTime = chrono::system_clock::now(); ss = stringstream(); ss << "insert into mt(BookId,BookName,BookTitle) values "; for (int j = 0; j < repeatedTimes; j++) { ss << "(" << ++num << ",'" << getUuid() << "','" << getUuid() << "')," << endl; } string str = ss.str(); int lastIndex = str.find_last_of(","); str = str.erase(lastIndex); state = mysql_query(conn, str.c_str()); endTime = chrono::system_clock::now(); if (state != 0) { cout << "Num=" << num << " failed!" << endl; return; } cout << "Loops=" << i + 1 << ",Num=" << num << " succeeded!,time cost:" << chrono::duration_cast<chrono::seconds>(endTime - startTime).count() << " seconds," << chrono::duration_cast<chrono::milliseconds>(endTime - startTime).count() << " milliseconds," << chrono::duration_cast<chrono::microseconds>(endTime - startTime).count() << " microseconds," << chrono::duration_cast<chrono::nanoseconds>(endTime - startTime).count() << " nanoseconds!!!" << endl << endl; } } catch (const std::exception &e) { std::cerr << e.what() << '\n'; } }
2.Compile
g++ -g -std=c++2a -I. -Wall -I/usr/include/mysql/ *.cpp -o h1 -L/usr/lib -lmysqlclient -luuid;
3.Execute
./h1 100;
标签:insert,char,endTime,int,into,bulk,startTime,mysql,include 来源: https://www.cnblogs.com/Fred1987/p/16275307.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。