为什么在mysql_query()返回成功后,mysql_store_result()有时会返回NULL

成功调用mysql_query()后,mysql_store_result()能够返回NULL。出现该情况时,表明出现了下述条件之一:

·         出现了malloc()故障(例如,如果结果集过大)。

·         无法读取数据(在连接上出现了错误)。

·         查询未返回数据(例如,它是INSERT、UPDATE或DELETE)。

通过调用mysql_field_count(),始终能检查语句是否应生成非空结果。如果mysql_field_count()返回0,结果为空,而且上一个查询是未返回值的语句(例如INSERT或DELETE)。如果mysql_field_count()返回非0值,语句应生成非空结果。关于这方面的示例,请参见mysql_field_count()函数介绍。

通过调用mysql_error()或mysql_errno(),可测试是否出现了错误。



摘录自http://www.iteedu.com/database/mysql/mysqlmanualcn/apis/null-mysql-store-result.php

前一个项目碰到过类似的问题,在某些机器上查询时,总是返回空集,还没有处理, 初步想法是添加重试机制,判断影响行数与实陆返回不一致, 再重新调用查询操作

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用`mysql_real_query`函数执行MySQL查询,您需要先初始化MySQL连接并建立与MySQL服务器的连接。以下是一个简单的示例: ```cpp #include <mysql/mysql.h> #include <iostream> int main() { // 初始化MySQL连接 MYSQL mysql; mysql_init(&mysql); // 建立与MySQL服务器的连接 if (!mysql_real_connect(&mysql, "localhost", "username", "password", "database", 0, NULL, 0)) { std::cout << "连接到MySQL服务器失败: " << mysql_error(&mysql) << std::endl; return 1; } // 执行查询 const char* query = "SELECT * FROM table"; if (mysql_real_query(&mysql, query, strlen(query)) != 0) { std::cout << "查询执行失败: " << mysql_error(&mysql) << std::endl; return 1; } // 获取查询结果集 MYSQL_RES* result = mysql_store_result(&mysql); if (result == NULL) { std::cout << "获取查询结果集失败: " << mysql_error(&mysql) << std::endl; return 1; } // 遍历结果集并获取数据 MYSQL_ROW row; while ((row = mysql_fetch_row(result))) { // 在这里处理每一行数据 // row[i] 表示第 i+1 列的数据,索引从0开始 } // 释放结果集内存 mysql_free_result(result); // 关闭与MySQL服务器的连接 mysql_close(&mysql); return 0; } ``` 在上述示例中,我们首先初始化了一个`MYSQL`结构体并使用`mysql_init`函数进行初始化。然后使用`mysql_real_connect`函数建立与MySQL服务器的连接,其中包括MySQL服务器的主机名、用户名、密码和数据库名。 接下来,我们使用`mysql_real_query`函数执行查询语句。如果执行失败,可以使用`mysql_error`函数获取错误信息。 如果查询执行成功,我们可以使用`mysql_store_result`函数获取结果集。然后,可以使用`mysql_fetch_row`函数遍历结果集中的每一行数据,并对数据进行处理。 最后,记得释放结果集内存,并使用`mysql_close`函数关闭与MySQL服务器的连接。 请注意,以上示例是一个简化版的代码,并没有考虑错误处理和异常情况。在实际应用中,建议添加适当的错误处理和异常处理机制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值