用C++帮我连接MySQL数据库
时间: 2023-11-03 10:10:56 浏览: 87
以下是一个简单的连接MySQL数据库的C程序示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <mysql/mysql.h>
int main() {
MYSQL *conn;
MYSQL_RES *res;
MYSQL_ROW row;
char *server = "localhost";
char *user = "username";
char *password = "password";
char *database = "database_name";
conn = mysql_init(NULL);
if (!mysql_real_connect(conn, server, user, password, database, 0, NULL, 0)) {
fprintf(stderr, "%s\n", mysql_error(conn));
exit(1);
}
if (mysql_query(conn, "SELECT * FROM table_name")) {
fprintf(stderr, "%s\n", mysql_error(conn));
exit(1);
}
res = mysql_use_result(conn);
while ((row = mysql_fetch_row(res)) != NULL) {
printf("%s %s %s\n", row[0], row[1], row[2]);
}
mysql_free_result(res);
mysql_close(conn);
return 0;
}
```
在上述示例中,我们首先定义了一个`MYSQL`类型的指针`conn`,用来保存数据库连接的句柄。然后定义了一个`MYSQL_RES`类型的指针`res`,用来保存查询结果集的句柄。接着定义了连接MySQL数据库需要用到的参数,包括服务器地址、用户名、密码和数据库名。
然后调用`mysql_init()`函数初始化连接句柄,然后调用`mysql_real_connect()`函数连接到MySQL数据库。如果连接失败,我们将打印错误信息并退出程序。
接下来调用`mysql_query()`函数执行一条SQL查询语句。如果查询失败,我们将打印错误信息并退出程序。
然后调用`mysql_use_result()`函数获取查询结果集的句柄,我们可以通过`mysql_fetch_row()`函数逐行获取查询结果。在这个示例中,我们只是简单地将每行结果输出到控制台上。
最后,我们释放结果集的句柄和连接句柄,并返回0表示程序正常结束。
阅读全文