C++项目——集群聊天服务器项目(六)MySQL模块

Hello,大家好啊,最近比较忙,没来得及更新项目,实在抱歉~今天就恢复更新拉~

在验证完网络模块与业务模块代码可以正常使用后,需完成的操作是与底层数据库进行交互,为实现各类用户查询、增删业务奠定良好的基础。本节内容主要完成与底层数据库的交互操作,一起来看看把~

项目流程如下:

1、项目环境搭建 C++项目——集群聊天服务器项目(一)项目介绍、环境搭建、Boost库安装、Muduo库安装、Linux与vscode配置_c++集群聊天服务器-CSDN博客

2、Json第三方库介绍

C++项目——集群聊天服务器项目(二)Json第三方库-CSDN博客

3、muduo网络库介绍

C++项目——集群聊天服务器项目(三)muduo网络库-CSDN博客

4、MySQL数据库创建

C++项目——集群聊天服务器项目(四)MySQL数据库-CSDN博客

5、网络模块与业务模块代码编写

C++项目——集群聊天服务器项目(五)网络模块与业务模块-CSDN博客

一、Mysql环境

在第一节中环境搭建中,有提示大家安装MySQL开发包,可以使用命令

sudo find /usr -name libmysqlclient*

去查看MySQL开发包是否安装好,查询结果如下:

各位这里十分重要哈,这牵扯到后续项目是否能正常登录查询操作底层数据库中存储的数据。

二、MySQL模块编写

2.1 编写MySQL类

在include/server目录下创建文件夹db,表示database数据库,db文件夹下创建头文件db.hpp,负责连接、操作数据库的基本操作

dp.hpp头文件如下:

#ifndef DB_H
#define DB_H

#include <mysql/mysql.h>//mysql的头文件 
#include <string>
using namespace std;

//数据库操作类
class MySQL
{
public:
    //初始化数据库连接
    MySQL();
    //释放数据库连接资源
    ~MySQL();
    //连接数据库
    bool connect();
    //更新操作
    bool update(string sql);
    //查询操作
    MYSQL_RES *query(string sql);
    //获取连接
    MYSQL* getConnection();
private:
    MYSQL *_conn;//连接 
};

#endif

相应的,在src/server/中创建文件夹db,db文件夹下创建库文件db.cpp,如图

对创建的MySQL类进行函数实现,db.cpp文件如下

#include "db.hpp"
#include <muduo/base/Logging.h>

//数据库配置信息
static string server = "127.0.0.1";
static string user = "root";
static string password = "123456";
static string dbname = "chat";

//初始化数据库连接
MySQL::MySQL()
{
    _conn = mysql_init(nullptr);
}

//释放数据库连接资源
MySQL::~MySQL()
{
    if (_conn != nullptr)
        mysql_close(_conn);
}

//连接数据库
bool MySQL::connect()
{
    MYSQL *p = mysql_real_connect(_conn, server.c_str(), user.c_str(),
                                  password.c_str(), dbname.c_str(), 3306, nullptr, 0);
    if (p != nullptr)
    {
        //C和C++代码默认的编码字符是ASCII,如果不设置,从MySQL上拉下来的中文显示?
        mysql_query(_conn, "set names gbk");
        LOG_INFO << "connect mysql success!";
    }
    else
    {
        LOG_INFO << "connect mysql fail!";
    }

    return p;
}

//更新操作
bool MySQL::update(string sql)
{
    if (mysql_query(_conn, sql.c_str()))
    {
        LOG_INFO << __FILE__ << ":" << __LINE__ << ":"
                 << sql << "更新失败!";
        return false;
    }

    return true;
}

//查询操作
MYSQL_RES *MySQL::query(string sql)
{
    if (mysql_query(_conn, sql.c_str()))
    {
        LOG_INFO << __FILE__ << ":" << __LINE__ << ":"
                 << sql << "查询失败!";
        return nullptr;
    }
    
    return mysql_use_result(_conn);
}

//获取连接
MYSQL* MySQL::getConnection()
{
    return _conn;
}

2.2 更新CMakeLists.txt文件

我们来依次更新一下CMakeLists.txt文件

在chat项目下的CMakeLists.txt文件,将头文件搜索路径更新

src/server中的CMakeLists.txt添加mysqlclient库文件,添加db目录中所有文件一起生成可执行文件

三、模块测试

此处只要使用CMake编译成功即可!

如果有问题,还请及时联系我,感谢大家的批评与指正!谢谢~

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-30 12:42:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-30 12:42:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-30 12:42:05       82 阅读
  4. Python语言-面向对象

    2024-03-30 12:42:05       91 阅读

热门阅读

  1. 了解监控易(13):数据库监控-功能模块解析

    2024-03-30 12:42:05       43 阅读
  2. python基础语法

    2024-03-30 12:42:05       38 阅读
  3. #设计模式#4.6 Flyweight(享元) 对象结构型模式

    2024-03-30 12:42:05       35 阅读
  4. 2024最新华为OD机试试题库全 -【跳马】- C卷

    2024-03-30 12:42:05       41 阅读
  5. Golang基础-3

    2024-03-30 12:42:05       36 阅读
  6. kanzi 3d知识点

    2024-03-30 12:42:05       42 阅读
  7. 了解HTTP安全标头(HTTP Security Headers)

    2024-03-30 12:42:05       42 阅读
  8. C++之常函数、常对象

    2024-03-30 12:42:05       41 阅读
  9. C 传递指针给函数

    2024-03-30 12:42:05       37 阅读
  10. Django vs Flask:选择最适合你的Python Web框架

    2024-03-30 12:42:05       36 阅读
  11. 应急响应流程与挖矿病毒排查流程

    2024-03-30 12:42:05       37 阅读
  12. <商务世界>《第28课 商务旅行的注意事项》

    2024-03-30 12:42:05       43 阅读