• C++ mysql read table


    //Utill.h
    #ifndef Util_H
    #define Util_H
    
    #include <chrono>
    #include <ctime>
    #include <fstream> 
    #include <iostream>
    #include "mysql_connection.h"
    #include <cppconn/driver.h>
    #include <cppconn/exception.h>
    #include <cppconn/resultset.h>
    #include <cppconn/statement.h>
    #include <cppconn/prepared_statement.h>
    #include <sstream>
    #include <stdlib.h>
    #include <thread>
    #include <unistd.h>
    #include <uuid/uuid.h>
    #include <vector>
    
    using namespace std;
    
    class Util
    {
    public:
        static char *uuidValue;
        static char *dtValue;
        char *getTime();
        char *getUuid(); 
        void readSQL5();
    };
    #endif
    
    
    
    
    //Util.cpp
    #include "Model/Util.h"
    
    char *Util::dtValue = (char *)malloc(20);
    char *Util::uuidValue = (char *)malloc(40);
    
    void Util::readSQL5()
    {
        try
        {
            sql::Driver *driver;
            sql::Connection *conn;
            sql::Statement *stmt;
            sql::PreparedStatement *pstmt;
            sql::ResultSet *res;
            sql::PreparedStatement *tablePstmt;
            sql::ResultSet *tableRes;
    
            driver = get_driver_instance();
            conn = driver->connect("tcp://127.0.0.1:3306", "root", "password");
            conn->setSchema("db");
    
            string selectTable = "select table_name from information_schema.tables where table_schema='db'";
            pstmt = conn->prepareStatement(selectTable);
            res = pstmt->executeQuery();
    
            vector<string> tableVec;
            while (res->next())
            {
                tableVec.push_back(res->getString(1));
            }
    
            vector<string>::iterator itr = tableVec.begin();
            cout << "Table:";
            while (itr != tableVec.end())
            {
                cout << *itr << "\t";
                itr++;
            }
            cout << endl << endl;
    
            uint64_t num = 0;
            int loop = 0;
            for (auto &tableName : tableVec)
            { 
                string sql = "select * from " + tableName;
                tablePstmt = conn->prepareStatement(sql);
                tableRes = tablePstmt->executeQuery();
                while (tableRes->next())
                {
                    if (++num % 500000 == 0)
                    {
                        cout <<"Loop="<<++loop << ",Num=" << num << ",Index=" << tableRes->getInt(1) << ",Id=" << tableRes->getInt64(2)
                             << ",Name=" << tableRes->getString(3) << ",Title=" << tableRes->getString(4) << endl;
                    }
                }
                cout << getTime() << ",finished in retrieving from " << tableName << endl<<endl;
            }
            conn->close();
            cout << "IsClosed=" << conn->isClosed() << endl;
            cout << getTime() << ",finished in void Util::readSQL5()!" << endl;
        }
        catch (sql::SQLException &ex)
        {
            cout << "#ERR: SQLException in " << __FILE__ << "," << __FUNCTION__ << "," << __LINE__ << endl;
            cout << ex.what() << endl;
            cout << "Error code:" << ex.getErrorCode() << ",state:" << ex.getSQLState() << endl;
            return;
        }
    }
    
    char *Util::getTime()
    {
        time_t rawTime = time(NULL);
        struct tm tmInfo = *localtime(&rawTime);
        strftime(dtValue, 20, "%Y%m%d%H%M%S", &tmInfo);
        return dtValue;
    }
    
    char *Util::getUuid()
    {
        uuid_t newUUID;
        uuid_generate(newUUID);
        uuid_unparse(newUUID, uuidValue);
        return uuidValue;
    }
    

      

    //main.cpp
    
    #include "Model/Util.h"
    
    void readTable5();
    
    
    int main(int args,char **argv)
    {
        try
        {
            readTable5();
        }
        catch(const std::exception& e)
        {
            std::cerr << e.what() << '\n';
        }
        
    }
    
    void readTable5()
    {
        Util ul;
        ul.readSQL5();
    }

    Compile:

    g++ -g -std=c++2a -I. *.cpp ./Model/*.cpp -o h1 -luuid -lpthread -lmysqlcppconn;

    Run

    time ./h1 -1;

  • 相关阅读:
    [转]苦逼男和女神之间的经典对话,亲身经历过的有木有啊,必须转。。。
    你是不是对异步Socket 很迷惑? 看完本文的一小类 你就知道大体该做什么,怎么做了....
    解决 由于本机的限制,该操作已被取消。请与系统管理员联系
    总是忘记ARGB8888的排列顺序。。。记一下,以后可以查看
    键盘 钩子 的代码
    MVC 4 诡异的 HTTP ERROR 404.20
    解决Silverlight在ChildWindow中进行DragDrop操作问题
    VS2012 未能正确加载Custom Doc Well Package包
    WPF XAML之bing使用StringFormat
    WPF MVVM之INotifyPropertyChanged接口的几种实现方式
  • 原文地址:https://www.cnblogs.com/Fred1987/p/16378165.html
Copyright © 2020-2023  润新知