当前位置:首页 > 行业动态 > 正文

c语言中用mysql函数实现数据库操作

在C语言中,可以使用MySQL C API来实现数据库操作。首先需要安装MySQL开发库,然后包含头文件 mysql.h,接着使用 mysql_init()初始化连接, mysql_real_connect()建立连接,通过 mysql_query()执行SQL语句,最后使用 mysql_close()关闭连接。

在C语言中,我们可以使用MySQL C API来实现数据库操作,以下是一个简单的示例,展示了如何使用MySQL C API连接到MySQL数据库、执行查询并处理结果。

c语言中用mysql函数实现数据库操作  第1张

1、安装MySQL C API库

确保已经安装了MySQL C API库,在Linux系统上,可以使用以下命令安装:

sudo aptget install libmysqlclientdev

2、包含必要的头文件

在C代码中,需要包含以下头文件:

#include <stdio.h>
#include <stdlib.h>
#include <mysql/mysql.h>

3、连接到MySQL数据库

使用mysql_init()函数初始化一个MYSQL对象,然后使用mysql_real_connect()函数连接到数据库。

MYSQL *conn;
conn = mysql_init(NULL);
if (conn == NULL) {
    fprintf(stderr, "%s
", mysql_error(conn));
    exit(1);
}
if (mysql_real_connect(conn, "localhost", "username", "password", "database", 0, NULL, 0) == NULL) {
    fprintf(stderr, "%s
", mysql_error(conn));
    mysql_close(conn);
    exit(1);
}

4、执行查询并处理结果

使用mysql_query()函数执行SQL查询,然后使用mysql_store_result()函数获取查询结果,遍历结果集并打印每一行的数据。

if (mysql_query(conn, "SELECT * FROM table_name")) {
    fprintf(stderr, "%s
", mysql_error(conn));
    mysql_close(conn);
    exit(1);
}
MYSQL_RES *result = mysql_store_result(conn);
if (result == NULL) {
    fprintf(stderr, "%s
", mysql_error(conn));
    mysql_close(conn);
    exit(1);
}
MYSQL_ROW row;
unsigned int num_fields = mysql_num_fields(result);
while ((row = mysql_fetch_row(result))) {
    for (unsigned int i = 0; i < num_fields; i++) {
        printf("%s ", row[i] ? row[i] : "NULL");
    }
    printf("
");
}
mysql_free_result(result);

5、关闭连接并释放资源

使用mysql_close()函数关闭数据库连接。

mysql_close(conn);

将以上代码片段组合在一起,就可以实现一个简单的C语言程序,用于连接MySQL数据库、执行查询并处理结果。

0