C++ 連接MySql

官方文檔

官方文檔


機(jī)器配置

機(jī)器環(huán)境:mac 10.14
mysql版本:8.0.4-rc,自行編譯,編譯步驟
mysql 存放路徑:/Users/shiyibo/LNMP/mysql
IDE: CLion


目錄劃分:

| - main.cpp
| - myDb.h
| - MyDb.cpp

代碼

/**
 * file MyDb.h
 *
 * Created by shiyibo on 2018/12/21.
 */

#ifndef DB_MYDB_H
#define DB_MYDB_H

#include <string>
#include "/Users/shiyibo/LNMP/mysql/include/mysql.h"

using namespace std;

class MyDb {

public:
    MyDb();
    ~MyDb();

    /**
     * 連接mysql
     *
     * @param host
     * @param user
     * @param pwd
     * @param db_name
     * @param port
     * @return
     */
    bool initDB(string host, string user,string pwd,string db_name, int port);

    /**
     * 執(zhí)行sql語(yǔ)句
     *
     * @param sql
     * @return
     */
    bool exeSQL(string sql);

private:
    /**
     * 連接mysql句柄指針
     */
    MYSQL *mysql;

    /**
     * 指向查詢結(jié)果的指針
     */
    MYSQL_RES *result;

    /**
     * 按行返回的查詢信息
     */
    MYSQL_ROW row;
};
#endif //DB_MYDB_H

/**
 * file MyDb.cpp
 * Created by shiyibo on 2018/12/21.
 */

#include <iostream>
#include <string>
#include "MyDb.h"

using namespace std;

/**
 * 初始化數(shù)據(jù)庫(kù)連接變量
 */
MyDb::MyDb()
{
    mysql = mysql_init(NULL);

    if(!mysql) {
        cout<<"Error:"<<mysql_error(mysql);
        exit(1);
    }
}

/**
 * 釋放資源
 */
MyDb::~MyDb()
{
    if(mysql) {
        mysql_close(mysql);
    }
}

/**
 *
 * @param host
 * @param user
 * @param passwd
 * @param db_name
 * @oaram port
 * @return
 */
bool MyDb::initDB(std::string host, std::string user, std::string passwd, std::string db_name, int port = 3306)
{
    mysql = mysql_real_connect(mysql, host.c_str(), user.c_str(), passwd.c_str(), db_name.c_str(), port, NULL, 0);
    if(!mysql) {
        cout << "Error: " << mysql_error(mysql);
        exit(1);
    }

    return true;
}

/**
 *  執(zhí)行sql 語(yǔ)句
 * @param sql
 * @return
 */
bool MyDb::exeSQL(std::string sql)
{
    //mysql_query()執(zhí)行成功返回0,執(zhí)行失敗返回非0值。
    if (mysql_query(mysql,sql.c_str())) {
        cout<<"Query Error: "<<mysql_error(mysql);
        return false;
    }

    result = mysql_store_result(mysql);

    if (result) {
        //獲取結(jié)果集中總共的字段數(shù),即列數(shù)
        int               num_fields = mysql_num_fields(result);
        unsigned long long  num_rows = mysql_num_rows(result);

        for(unsigned long long i = 0; i < num_rows; i++) {
            row = mysql_fetch_row(result);
            if(!row) {
                break;
            }

            for(int j=0;j<num_fields;j++) {
                cout<<row[j]<<"\t\t";
            }
            cout<<endl;
        }
    } else {
        //代表執(zhí)行的是update,insert,delete類的非查詢語(yǔ)句
        if (mysql_field_count(mysql) == 0) {
            // 返回update,insert,delete影響的行數(shù)
            unsigned long long num_rows = mysql_affected_rows(mysql);

            return num_rows;
        } else {
            cout << "Get result error: " << mysql_error(mysql);
            return false;
        }
    }

    return true;
}

#include <iostream>
#include "MyDb.h"

int main() {
    // std::cout << "Hello, World!" << std::endl;

    MyDb db;

    string host = "127.0.0.1";
    string user = "root";
    string passwd = "password";
    string dbName = "test";
    int port = 3307;

    cout<<"start\n";

    //連接數(shù)據(jù)庫(kù)
    bool conn = db.initDB(host, user, passwd, dbName, port);

    if (!conn) {
        cout<<"connect fails\n";
    }

    cout<<"ok" <<endl;

    //將用戶信息添加到數(shù)據(jù)庫(kù)
    string sql = "INSERT account values(1, 'fengxin');";
    db.exeSQL(sql);

    sql = "INSERT account values(2, 'axin');";
    db.exeSQL(sql);

    //將所有用戶信息讀出,并輸出。
    sql = "SELECT * from account;";
    db.exeSQL(sql);

    return 0;
}


編譯

g++  main.cpp MyDB.cpp -o main  `mysql_config --cflags --libs`

運(yùn)行

image.png

數(shù)據(jù)表

CREATE TABLE `account` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(25) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
)
image.png

問(wèn)題

  • 運(yùn)行時(shí)遇到如下報(bào)錯(cuò)
./main
dyld: Library not loaded: @rpath/libmysqlclient.21.dylib
  Referenced from: /Users/shiyibo/CLionProjects/db/./main
  Reason: image not found
Abort trap: 6

解決方案:

 1、關(guān)閉csrutil
 2、找到mysql安裝路徑,建立軟連接

sudo ln -s /usr/local/mysql/lib/libmysqlclient.21.dylib /usr/lib/libmysqlclient.21.dylib

效果: 原意是,建立一個(gè)從/usr/lib/libmysqlclient.21.dylib/usr/local/mysql/lib/libmysqlclient.21.dylib的軟連;
環(huán)境中編譯的地址為 /Users/shiyibo/LNMP/mysql,默認(rèn)的按照路徑/usr/local/mysql/lib/libmysqlclient.21.dylib中沒(méi)有這個(gè)目錄;
換成了
sudo ln -s /Users/shiyibo/LNMP/mysql/lib/libmysqlclient.21.dylib /usr/lib/libmysqlclient21.dylib,重試,不管用;

sudo ln -s /usr/local/mysql/lib/libmysqlclient.18.dylib/usr/lib/libmysqlclient.18.dylib     
或
export DYLD_LIBRARY_PATH="$DYLD_LIBRARY_PATH:/usr/local/mysql/lib/"

使用第二種方案,可以成功編譯,當(dāng)然,路徑也得換為/Users/shiyibo/LNMP/mysql/lib


最后

好多年不寫C系列,代碼丑陋,生疏,敬請(qǐng)諒解!

參考

Linux下C++連MySQL數(shù)據(jù)庫(kù)

linux下c++連接mysql數(shù)據(jù)庫(kù)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容