c语言中mysql_query的概念和使用案例
在 C 语言中,使用 MySQL 数据库需要用到 MySQL C API。mysql_query()
函数是 MySQL C API 中的一个函数,用于执行 SQL 语句。
概念
mysql_query()
函数的原型如下:
int mysql_query(MYSQL *mysql, const char *stmt_str)
mysql
:这是一个指向MYSQL
结构的指针,该结构代表到一个 MySQL 服务器的连接。stmt_str
:这是一个指向 SQL 语句的指针,该语句以 null 终止的字符串形式传递。
该函数执行成功时返回 0,如果发生错误则返回非 0 值。要获取错误的详细信息,可以使用mysql_error()
函数。
使用案例
以下是 mysql_query()
函数在 C 语言中的使用案例:
1. 连接到 MySQL 数据库
在执行任何查询之前,你需要先连接到 MySQL 数据库。
#include <mysql/mysql.h>
#include <stdio.h>
int main() {
MYSQL *conn;
MYSQL_RES *res;
MYSQL_ROW row;
char *server = "localhost";
char *user = "username";
char *password = "password";
char *database = "mydb";
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);
}
// 执行 SQL 查询
if (mysql_query(conn, "SELECT * FROM users")) {
fprintf(stderr, "%s\n", mysql_error(conn));
exit(1);
}
// 存储结果集
res = mysql_use_result(conn);
// 输出结果集
while ((row = mysql_fetch_row(res)) != NULL) {
printf("%s\n", row[0]);
}
// 释放结果集
mysql_free_result(res);
// 关闭连接
mysql_close(conn);
return 0;
}
在这个例子中,我们首先初始化一个 MYSQL
结构,然后使用 mysql_real_connect()
函数连接到 MySQL 服务器。之后,我们使用 mysql_query()
函数执行一个 SELECT 查询,并使用 mysql_use_result()
函数来获取查询结果。最后,我们通过 mysql_fetch_row()
函数遍历结果集,并使用 mysql_free_result()
释放结果集资源,最后关闭数据库连接。
请注意,MySQL C API 已经被标记为不推荐使用,推荐使用 MySQL Connector/C++ 或 MySQL Connector/C 来替代。上面的示例代码使用了旧的 MySQL C API,在实际开发中,你应该使用更现代的库。