当前位置: 首页 > news >正文

使用C语言连接MySQL

在C语言中连接MySQL数据库,通常需要使用MySQL提供的C API。以下是使用C语言连接MySQL数据库的基本步骤和示例代码:
步骤 1: 安装MySQL C API
首先,确保你的系统上安装了MySQL数据库,并且安装了MySQL C API库。在大多数Linux发行版中,你可以通过包管理器安装libmysqlclient-dev或mysql-devel包。
步骤 2: 包含头文件
在你的C程序中包含MySQL C API的头文件。
#include <mysql.h>
#include <stdio.h>
#include <stdlib.h>

步骤 3: 初始化MySQL连接
使用mysql_init函数初始化一个MySQL连接对象。
MYSQL *conn = mysql_init(NULL);
if (conn == NULL) {
    fprintf(stderr, "MySQL initialization failed\n");
    exit(1);
}

步骤 4: 连接到MySQL服务器
使用mysql_real_connect函数连接到MySQL服务器。
if (mysql_real_connect(conn, "hostname", "username", "password", "database_name", 0, NULL, 0) == NULL) {
    fprintf(stderr, "MySQL connection error: %s\n", mysql_error(conn));
    mysql_close(conn);
    exit(1);
}

步骤 5: 执行SQL查询
使用mysql_query函数执行SQL查询。
if (mysql_query(conn, "SELECT * FROM table_name")) {
    fprintf(stderr, "MySQL query error: %s\n", mysql_error(conn));
    mysql_close(conn);
    exit(1);
}

步骤 6: 处理查询结果
使用mysql_store_result和mysql_fetch_row函数处理查询结果。
MYSQL_RES *result = mysql_store_result(conn);
MYSQL_ROW row;
while ((row = mysql_fetch_row(result))) {
    printf("%s \t %s \t %s\n", row[0], row[1], row[2]);
}
mysql_free_result(result);

步骤 7: 关闭连接
完成操作后,关闭MySQL连接。
mysql_close(conn);

完整示例代码
#include <mysql.h>
#include <stdio.h>
#include <stdlib.h>

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

    conn = mysql_init(NULL);
    if (conn == NULL) {
        fprintf(stderr, "MySQL initialization failed\n");
        exit(1);
    }

    if (mysql_real_connect(conn, "hostname", "username", "password", "database_name", 0, NULL, 0) == NULL) {
        fprintf(stderr, "MySQL connection error: %s\n", mysql_error(conn));
        mysql_close(conn);
        exit(1);
    }

    if (mysql_query(conn, "SELECT * FROM table_name")) {
        fprintf(stderr, "MySQL query error: %s\n", mysql_error(conn));
        mysql_close(conn);
        exit(1);
    }

    result = mysql_store_result(conn);
    while ((row = mysql_fetch_row(result))) {
        printf("%s \t %s \t %s\n", row[0], row[1], row[2]);
    }
    mysql_free_result(result);

    mysql_close(conn);

    return 0;
}

编译和链接
编译时,需要链接MySQL C API库:
gcc -o mysql_example mysql_example.c $(mysql_config --cflags --libs)

请确保将mysql_example.c替换为你的源文件名,并且mysql_config命令能够正确执行(这取决于你的MySQL安装和配置)。
以上是一个基本的C语言连接MySQL的示例。在实际应用中,你可能需要处理更复杂的SQL语句、事务、错误处理等。

http://www.lryc.cn/news/506702.html

相关文章:

  • PyTorch 2.0 以下版本中设置默认使用 GPU 的方法
  • 信号槽【QT】
  • 【UE5 C++课程系列笔记】10——动态单播/多播的基本使用
  • 点击展示大图预览
  • 【C++】分书问题:深入解析、回溯法高级应用与理论拓展
  • java开发入门学习五-流程控制
  • 【FFmpeg 教程 一】截图
  • 北邮,成电计算机考研怎么选?
  • 深入了解京东API接口:如何高效获取商品详情与SKU信息
  • C++常见内存泄漏案例分析以及解决方案
  • [LeetCode-Python版]206. 反转链表(迭代+递归两种解法)
  • 70 mysql 中事务的隔离级别
  • C语言二叉树
  • 智能工厂的设计软件 三种处理单元(NPU/GPU/CPU)及其在深度学习框架中的作用 之1
  • iOS swift开发系列--如何给swiftui内容视图添加背景图片显示
  • jmeter后端监视器
  • 服务器数据恢复—RAIDZ离线硬盘数超过热备盘数导致阵列崩溃的数据恢复案例
  • 面试题整理4----lvs,nginx,haproxy区别和使用场景
  • iOS - 超好用的隐私清单修复脚本(持续更新)
  • html <a>设置发送邮件链接、打电话链接 <a href=“mailto:></a> <a href=“tel:></a>
  • clickhouse-副本和分片
  • 2009 ~ 2019 年 408【计算机网络】大题解析
  • vue2使用render,js中写html
  • 如何有效划分服务器磁盘空间?具体的步骤和流程
  • labelme标签批量转换数据集json_to_dataset
  • Fisco-Bcos-java-SDK 利用java与fisco-Bcos区块链上的智能合约交互(以HelloWorld为例)
  • OpenHarmony-3.HDF Display子系统(6)
  • Nginx中Server块配置的详细解析
  • php学习资料分享
  • EE308FZ_Sixth Assignment_Beta Sprint_Sprint Essay 3