在C语言中连接MySQL数据库需要借助MySQL提供的官方客户端库,通常称为MySQL C API,这一过程涉及库的安装、环境配置、连接建立、SQL执行及资源释放等步骤,下面将详细介绍具体实现方法。

开发环境准备
在开始编码前,需确保系统已安装MySQL服务器及开发库,以Linux系统为例,可通过包管理器安装:sudo apt-get install libmysqlclient-dev(Ubuntu/Debian)或sudo yum install mysql-devel(CentOS/RHEL),Windows环境下,需从MySQL官网下载Connector/C,并配置包含目录和库目录到开发环境(如Visual Studio的包含目录和链接器输入),安装完成后,需包含头文件#include <mysql.h>,并在编译时链接mysqlclient库,例如使用gcc编译时添加参数-lmysqlclient。
建立数据库连接
连接MySQL的核心是初始化连接句柄并调用mysql_real_connect函数,首先定义MYSQL结构体指针,通过mysql_init分配内存,随后使用mysql_real_connect建立连接,该函数需要服务器地址、用户名、密码、数据库名、端口号等参数。
MYSQL *conn;
conn = mysql_init(NULL);
if (!mysql_real_connect(conn, "localhost", "user", "password", "testdb", 0, NULL, 0)) {
fprintf(stderr, "Connection error: %sn", mysql_error(conn));
exit(1);
} 若连接成功,conn将指向有效的连接对象,后续操作均基于此句柄。
执行SQL语句
连接成功后,可通过mysql_query或mysql_real_query执行SQL语句,前者适用于无参数的简单查询,后者可处理包含二进制数据的复杂语句,执行查询后,需通过mysql_store_result或mysql_use_result获取结果集,以查询为例:

if (mysql_query(conn, "SELECT id, name FROM users")) {
fprintf(stderr, "Query error: %sn", mysql_error(conn));
} else {
MYSQL_RES *result = mysql_store_result(conn);
MYSQL_ROW row;
while ((row = mysql_fetch_row(result))) {
printf("ID: %s, Name: %sn", row[0], row[1]);
}
mysql_free_result(result);
} 对于非查询语句(如INSERT、UPDATE),可通过mysql_affected_rows获取受影响的行数。
处理错误与释放资源
MySQL操作中需始终检查错误状态,mysql_error函数可返回最近操作的错误信息,完成所有操作后,必须按顺序释放资源:先调用mysql_free_result释放结果集,再通过mysql_close关闭连接,最后让系统回收MYSQL结构体内存。
mysql_close(conn);
未正确释放资源可能导致内存泄漏或连接耗尽。
完整示例代码
以下是一个完整的连接与查询示例:

#include <mysql.h>
#include <stdio.h>
int main() {
MYSQL *conn = mysql_init(NULL);
if (!conn) {
fprintf(stderr, "mysql_init failedn");
return 1;
}
if (!mysql_real_connect(conn, "localhost", "root", "123456", "test", 0, NULL, 0)) {
fprintf(stderr, "Connection failed: %sn", mysql_error(conn));
mysql_close(conn);
return 1;
}
if (mysql_query(conn, "SELECT * FROM students")) {
fprintf(stderr, "Query failed: %sn", mysql_error(conn));
mysql_close(conn);
return 1;
}
MYSQL_RES *result = mysql_store_result(conn);
MYSQL_ROW row;
while (row = mysql_fetch_row(result)) {
printf("%s %sn", row[0], row[1]);
}
mysql_free_result(result);
mysql_close(conn);
return 0;
} 相关问答FAQs
Q1:连接MySQL时出现“Can’t connect to MySQL server on ‘localhost’ (10061)”错误如何解决?
A:该错误通常表示客户端无法连接到MySQL服务器,可能原因包括:MySQL服务未启动(需通过sudo systemctl start mysql启动)、防火墙阻止连接(检查端口3306是否开放)、或用户名/密码错误,可通过netstat -tuln | grep 3306确认端口监听状态,并使用mysql -u root -p测试本地连接是否正常。
Q2:如何在C程序中处理MySQL的预处理语句(Prepared Statements)?
A:预处理语句可有效防止SQL注入并提升性能,使用mysql_stmt_init初始化语句句柄,mysql_stmt_prepare准备SQL语句,mysql_stmt_bind_param绑定参数,mysql_stmt_execute执行,最后通过mysql_stmt_fetch获取结果。
MYSQL_STMT *stmt = mysql_stmt_init(conn);
mysql_stmt_prepare(stmt, "INSERT INTO users(name) VALUES(?)", strlen("INSERT INTO users(name) VALUES(?)"));
MYSQL_BIND bind;
char name[50] = "John";
bind.buffer_type = MYSQL_TYPE_STRING;
bind.buffer = name;
bind.buffer_length = strlen(name);
mysql_stmt_bind_param(stmt, &bind);
mysql_stmt_execute(stmt);
mysql_stmt_close(stmt); 【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!
发表回复