C++ 连接MySql

官方文档

官方文档


机器配置

机器环境: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);

    /**
     * 执行sql语句
     *
     * @param sql
     * @return
     */
    bool exeSQL(string sql);

private:
    /**
     * 连接mysql句柄指针
     */
    MYSQL *mysql;

    /**
     * 指向查询结果的指针
     */
    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;

/**
 * 初始化数据库连接变量
 */
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;
}

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

    result = mysql_store_result(mysql);

    if (result) {
        //获取结果集中总共的字段数,即列数
        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 {
        //代表执行的是update,insert,delete类的非查询语句
        if (mysql_field_count(mysql) == 0) {
            // 返回update,insert,delete影响的行数
            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";

    //连接数据库
    bool conn = db.initDB(host, user, passwd, dbName, port);

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

    cout<<"ok" <<endl;

    //将用户信息添加到数据库
    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`

运行

image.png

数据表

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

问题

  • 运行时遇到如下报错
./main
dyld: Library not loaded: @rpath/libmysqlclient.21.dylib
  Referenced from: /Users/shiyibo/CLionProjects/db/./main
  Reason: image not found
Abort trap: 6

解决方案:

 1、关闭csrutil
 2、找到mysql安装路径,建立软连接

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

效果: 原意是,建立一个从/usr/lib/libmysqlclient.21.dylib/usr/local/mysql/lib/libmysqlclient.21.dylib的软连;
环境中编译的地址为 /Users/shiyibo/LNMP/mysql,默认的按照路径/usr/local/mysql/lib/libmysqlclient.21.dylib中没有这个目录;
换成了
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/"

使用第二种方案,可以成功编译,当然,路径也得换为/Users/shiyibo/LNMP/mysql/lib


最后

好多年不写C系列,代码丑陋,生疏,敬请谅解!

参考

Linux下C++连MySQL数据库

linux下c++连接mysql数据库

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353

推荐阅读更多精彩内容