C/C++链接数据库(MySQL)超级详细指南

news2024/12/26 19:24:16

C/C++链接数据库(MySQL)超级详细指南

在C/C++编程中,与数据库进行交互是一项常见的任务。MySQL作为一个广泛使用的开源关系型数据库管理系统,提供了丰富的API供C/C++开发者使用。本文将详细介绍如何在C/C++程序中链接MySQL数据库,包括环境配置、库文件引入、连接数据库、执行SQL语句、处理查询结果等关键步骤。

一、环境配置

在使用C/C++链接MySQL数据库之前,需要确保你的开发环境中已经安装了MySQL数据库以及相应的开发库。

  1. 安装MySQL

    前往MySQL官网,根据你的操作系统下载并安装MySQL服务器。安装过程中,请确保选择包含开发库(如MySQL Connector/C)的选项。

  2. 配置开发环境

    • Windows
      在Windows上,安装MySQL后,开发库通常位于MySQL安装目录下的libinclude文件夹中。你需要在你的C/C++项目中配置这些路径,以便编译器和链接器能够找到MySQL的头文件和库文件。

    • Linux
      在Linux上,你可以通过包管理器(如apt-get、yum等)安装MySQL开发库。例如,在Ubuntu上,你可以使用以下命令安装:

      sudo apt-get install libmysqlclient-dev
      

      安装后,头文件通常位于/usr/include/mysql,库文件位于/usr/lib/x86_64-linux-gnu/(路径可能因系统和MySQL版本而异)。

二、库文件引入

在你的C/C++项目中,你需要引入MySQL的头文件,并在编译时链接MySQL的库文件。

  1. 包含头文件

    在你的C/C++源文件中,包含MySQL的头文件:

    #include <mysql.h>
    
  2. 配置项目

    • Visual Studio
      在Visual Studio中,你需要通过项目属性配置包含目录和库目录,以及附加依赖项。

      • 右键点击项目 -> 属性 -> 配置属性 -> VC++目录 -> 包含目录,添加MySQL的include路径。
      • 配置属性 -> VC++目录 -> 库目录,添加MySQL的lib路径。
      • 配置属性 -> 链接器 -> 输入 -> 附加依赖项,添加libmysql.lib(Windows上)或mysqlclient(Linux上,可能需要添加前缀和后缀,如-lmysqlclient)。
    • Linux
      在Linux上,你通常使用g++或clang++进行编译。编译时,你需要使用-I选项指定头文件路径,使用-L选项指定库文件路径,并使用-l选项链接库文件。例如:

      g++ -o my_program my_program.cpp -I/usr/include/mysql -L/usr/lib/x86_64-linux-gnu/ -lmysqlclient
      
三、连接数据库

在C/C++中,连接MySQL数据库通常使用mysql_real_connect函数。

  1. 初始化MySQL对象

    在连接数据库之前,你需要初始化一个MySQL对象:

    MYSQL *conn = mysql_init(NULL);
    if (conn == NULL) {
        fprintf(stderr, "mysql_init() failed\n");
        exit(1);
    }
    
  2. 连接数据库

    使用mysql_real_connect函数连接数据库:

    if (mysql_real_connect(conn, "host", "user", "password", 
            "database", 0, NULL, 0) == NULL) {
        fprintf(stderr, "mysql_real_connect() failed\n");
        mysql_close(conn);
        exit(1);
    }
    

    其中,"host"是数据库服务器的地址,"user"是数据库用户名,"password"是数据库密码,"database"是要连接的数据库名称。

四、执行SQL语句

连接数据库后,你可以使用mysql_querymysql_real_query函数执行SQL语句。

  1. 执行SQL查询

    使用mysql_query执行简单的SQL查询:

    if (mysql_query(conn, "SELECT * FROM table_name")) {
        fprintf(stderr, "SELECT * error: %s\n", mysql_error(conn));
        mysql_close(conn);
        exit(1);
    }
    
  2. 处理查询结果

    使用mysql_store_resultmysql_use_result函数获取查询结果。mysql_store_result会将整个结果集加载到内存中,适用于结果集较小的情况;mysql_use_result则逐行处理结果集,适用于结果集较大的情况。

    • 使用mysql_store_result

      MYSQL_RES *result = mysql_store_result(conn);
      if (result == NULL) {
          fprintf(stderr, "mysql_store_result() failed. Error: %s\n", mysql_error(conn));
          mysql_close(conn);
          exit(1);
      }
      
      int num_fields = mysql_num_fields(result);
      MYSQL_ROW row;
      
      while ((row = mysql_fetch_row(result))) {
          for(int i = 0; i < num_fields; i++) {
              printf("%s ", row[i] ? row[i] : "NULL");
          }
          printf("\n");
      }
      
      mysql_free_result(result);
      
    • 使用mysql_use_result

      MYSQL_RES *result = mysql_use_result(conn);
      if (result == NULL) {
          fprintf(stderr, "mysql_use_result() failed. Error: %s\n", mysql_error(conn));
          mysql_close(conn);
          exit(1);
      }
      
      MYSQL_ROW row;
      while ((row = mysql_fetch_row(result))) {
          // 处理每一行数据
      }
      
      mysql_free_result(result);
      
五、关闭数据库连接

在完成数据库操作后,你需要关闭数据库连接以释放资源。

mysql_close(conn);
六、错误处理

在处理数据库操作时,你应该始终检查每个函数的返回值,并在出现错误时打印错误信息。MySQL的API提供了mysql_error函数来获取最近一次操作的错误信息。

七、示例程序

以下是一个完整的C++程序示例,它展示了如何连接MySQL数据库、执行查询并处理结果:

#include <mysql.h>
#include <iostream>
#include <cstdlib>

int main() {
    MYSQL *conn;
    MYSQL_RES *res;
    MYSQL_ROW row;

    // 初始化MySQL对象
    conn = mysql_init(NULL);

    // 检查初始化是否成功
    if (conn == NULL) {
        std::cerr << "mysql_init() failed" << std::endl;
        exit(1);
    }

    // 连接数据库
    if (mysql_real_connect(conn, "localhost", "root", "password", 
            "database_name", 0, NULL, 0) == NULL) {
        std::cerr << "mysql_real_connect() failed. Error: " << mysql_error(conn) << std::endl;
        mysql_close(conn);
        exit(1);
    }

    // 执行SQL查询
    if (mysql_query(conn, "SELECT * FROM table_name")) {
        std::cerr << "SELECT * error: " << mysql_error(conn) << std::endl;
        mysql_close(conn);
        exit(1);
    }

    // 获取查询结果
    res = mysql_store_result(conn);
    if (res == NULL) {
        std::cerr << "mysql_store_result() failed. Error: " << mysql_error(conn) << std::endl;
        mysql_close(conn);
        exit(1);
    }

    // 处理查询结果
    int num_fields = mysql_num_fields(res);
    while ((row = mysql_fetch_row(res))) {
        for (int i = 0; i < num_fields; i++) {
            std::cout << (row[i] ? row[i] : "NULL") << " ";
        }
        std::cout << std::endl;
    }

    // 释放查询结果
    mysql_free_result(res);

    // 关闭数据库连接
    mysql_close(conn);

    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2251855.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

思科网络设备常用命令整理

思科网络设备的配置命令非常丰富&#xff0c;广泛应用于路由器、交换机和其他网络设备的管理与配置。以下是一些常见的思科设备配置命令&#xff0c;按照功能分类&#xff0c;以帮助你快速查找和使用。 一、基本命令 查看当前配置和状态 show running-config&#xff1a;查看…

2024年信号处理与神经网络应用(SPNNA 2024)

会议官网&#xff1a;www.spnna.org 会议时间&#xff1a;2024年12月13-15日 会议地点&#xff1a;中国武汉

Leecode经典题3-删除排序数组中的重复项

删除排序数组中的重复项 题目描述&#xff1a; 给你一个 非严格递增排列 的数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使每个元素 只出现一次 &#xff0c;返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。 …

无人机数据处理系统:原理与核心系统

一、数据处理系统的运行原理 数据获取&#xff1a;无人机在飞行过程中&#xff0c;通过搭载的传感器&#xff08;如相机、激光雷达等&#xff09;采集到各种类型的数据&#xff0c;例如图像、点云等。这些数据是后续处理和分析的基础。 数据传输&#xff1a;采集到的数据会通…

ElasticSearch学习篇19_《检索技术核心20讲》搜推广系统设计思想

目录 主要是包含搜推广系统的基本模块简单介绍&#xff0c;另有一些流程、设计思想的分析。 搜索引擎 基本模块检索流程 查询分析查询纠错 广告引擎 基于标签倒排索引召回基于向量ANN检索召回打分机制&#xff1a;非精确打分精准深度学习模型打分索引精简&#xff1a;必要的…

【尚筹网】五、管理员维护

【尚筹网】五、管理员维护 任务清单分页管理管理员信息目标思路代码引入 PageHelperAdminMapper 中编写 SQL 语句AdminMapper 接口生成方法AdminServiceAdminHandler页面显示主体在页面上使用 Pagination 实现导航条 关键词查询页面上调整表单在翻页时保持关键词查询条件 单条删…

MySQL 启动失败问题分析与解决方案:`mysqld.service failed to run ‘start-pre‘ task`

目录 前言1. 问题背景2. 错误分析2.1 错误信息详解2.2 可能原因 3. 问题排查与解决方案3.1 检查 MySQL 错误日志3.2 验证 MySQL 配置文件3.3 检查文件和目录权限3.4 手动启动 MySQL 服务3.5 修复 systemd 配置文件3.6 验证依赖环境 4. 进一步优化与自动化处理结语 前言 在日常…

Apache storm UI如何更换默认8080端口

在搭建Apache storm环境的时候&#xff0c;遇到Apache storm UI默认端口是8080&#xff0c;但是这个端口会被其他java程序占用&#xff0c;导致Apache storm UI服务无法启动。报错Exception in thread “main” java.lang.RuntimeException: java.io.IOException: Failed to bi…

FPGA实现串口升级及MultiBoot(十)串口升级SPI FLASH实现

本文目录索引 工程架构example9工程设计Vivado设计Vitis设计example9工程验证1、读取FLASH ID2、擦除整个FLASH3、Blank-Check4、烧写Golden区位流5、读取FLASH内容6、烧写MultiBoot区位流(升级位流)7、MultiBoot区位流(升级位流)启动example10工程设计Vivado设计Vitis设计exam…

图解人工智能:从规则到深度学习的全景解析

&#x1f31f;作者简介&#xff1a;热爱数据分析&#xff0c;学习Python、Stata、SPSS等统计语言的小高同学~&#x1f34a;个人主页&#xff1a;小高要坚强的博客&#x1f353;当前专栏&#xff1a;Python之机器学习&#x1f34e;本文内容&#xff1a;图解人工智能&#xff1a;…

Binder架构

一、架构 如上图&#xff0c;binder 分为用户层和驱动层两部分&#xff0c;用户层有客户端&#xff08;Client&#xff09;、服务端&#xff08;Server&#xff09;、服务管理&#xff08;ServiceManager&#xff09;。 从用户空间的角度&#xff0c;使用步骤如下&#xff08;…

基于springboot中小型制造企业质量管理系统源码和论文

信息数据从传统到当代&#xff0c;是一直在变革当中&#xff0c;突如其来的互联网让传统的信息管理看到了革命性的曙光&#xff0c;因为传统信息管理从时效性&#xff0c;还是安全性&#xff0c;还是可操作性等各个方面来讲&#xff0c;遇到了互联网时代才发现能补上自古以来的…

Flutter 权限申请

这篇文章是基于permission_handler 10.2.0版本写的 前言 在App开发过程中我们经常要用到各种权限&#xff0c;我是用的是permission_handler包来实现权限控制的。 pub地址&#xff1a;https://pub.dev/packages/permission_handler permission_handler 权限列表 变量 Androi…

MATLAB期末复习笔记(下)

五、数据和函数的可视化 1.MATLAB的可视化对象 图形对象是 MATLAB用来创建可视化数据的组件。每个对象都有一个名为句柄 的唯一标识符。使用该句柄&#xff0c;您可以通过设置对象 属性 来操作现有图形对象的特征 ROOT: &#xff1a;即电脑屏幕 Figure &#xff1a;图窗…

web安全从0到1:burp-suite3

声明&#xff01; 学习视频来自B站up主 **泷羽sec** 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以及泷羽sec团队无关&a…

深度学习:梯度下降法

损失函数 L&#xff1a;衡量单一训练样例的效果。 成本函数 J&#xff1a;用于衡量 w 和 b 的效果。 如何使用梯度下降法来训练或学习训练集上的参数w和b &#xff1f; 成本函数J是参数w和b的函数&#xff0c;它被定义为平均值&#xff1b; 损失函数L可以衡量你的算法效果&a…

Linux:文件系统inode

早期&#xff0c;存储文件的设备是磁盘&#xff08;当下的市场几乎都是SSD&#xff09;&#xff0c;但大家习惯的把它们都称为磁盘&#xff0c;磁盘是用来表示区分内存的存储设备。而在操作系统看来&#xff0c;这个存储设备的结构就是一个线性结构&#xff0c;这一点很重要。 …

94.【C语言】解析预处理(2)

目录 1.带有副作用的宏参数 代码 一个判断最大值的宏代码 运行结果 分析 "副作用"的解释 2.宏替换规则 解释 3.宏和函数的对比 附一张对比表 承接93.【C语言】解析预处理(1)文章 1.带有副作用的宏参数 代码 一个判断最大值的宏代码 #define MAX(a, b) (…

Linux学习笔记12 systemd的其他命令

前文已经介绍了systemd在系统初始化中起到的作用和服务的管理和配置。这里补充一下systemd的其他工具和系统进程的管理 前文 Linux学习笔记10 系统启动初始化&#xff0c;服务和进程管理&#xff08;上&#xff09;-CSDN博客 Linux学习笔记11 系统启动初始化&#xff0c;服务…

vue3+ts+uniapp微信小程序顶部导航栏

这是colorui改的&#xff0c;不用就不用看啦 color-ui(https://docs.xzeu.com/#/) 新建component文件夹创建topNavigation.vue <template><view><view class"cu-custom" :style"height: CustomBar px"><view class"cu-bar…