mysql_init
是 MySQL C API 中的一个函数,用于初始化一个 MYSQL
结构,这个结构在后续的 MySQL 数据库操作中会被频繁使用。mysql_init
的调用是建立与 MySQL 数据库连接的第一步。
函数原型:
MYSQL *mysql_init(MYSQL *mysql);
参数说明:
mysql
:一个指向MYSQL
结构的指针。如果传递NULL
,mysql_init
将分配并初始化一个新的MYSQL
结构。如果不为NULL
,则该函数将初始化已存在的MYSQL
结构。
返回值:
- 成功:返回一个指向已初始化
MYSQL
结构的指针。 - 失败:返回
NULL
。
使用案例:
以下是一个使用 mysql_init
函数的简单例子,该例子初始化一个 MYSQL
结构,并尝试与 MySQL 数据库建立连接。
#include <mysql/mysql.h>
#include <stdio.h>
int main() {
MYSQL *conn;
MYSQL_RES *res;
MYSQL_ROW row;
// 初始化 MYSQL 结构
conn = mysql_init(NULL);
// 检查是否初始化成功
if (conn == NULL) {
fprintf(stderr, "%s\n", mysql_error(conn));
return 1;
}
// 连接到 MySQL 服务器
if (mysql_real_connect(conn, "host", "user", "password", "database", 0, NULL, 0) == NULL) {
fprintf(stderr, "%s\n", mysql_error(conn));
mysql_close(conn);
return 1;
}
// 执行 SQL 查询
if (mysql_query(conn, "SELECT * FROM table_name")) {
fprintf(stderr, "%s\n", mysql_error(conn));
mysql_close(conn);
return 1;
}
// 存储结果集
res = mysql_store_result(conn);
// 打印结果集
while ((row = mysql_fetch_row(res)) != NULL) {
printf("%s\n", row[0]);
}
// 释放结果集
mysql_free_result(res);
// 关闭连接
mysql_close(conn);
return 0;
}
在这个例子中,我们首先调用 mysql_init
来初始化一个 MYSQL
结构。然后,我们使用 mysql_real_connect
尝试连接到 MySQL 服务器。如果连接成功,我们执行一个 SQL 查询,并使用 mysql_store_result
存储查询结果。最后,我们遍历结果集,打印出查询结果,并释放结果集资源以及关闭数据库连接。
请注意,在实际应用中,你需要将 "host"
, "user"
, "password"
, 和 "database"
替换为实际的数据库连接信息,并且确保已经包含了 MySQL 客户端库的头文件,并链接了相应的库文件。