有关Mysql的mysql_store_result函数返回NULL的情况以及其他注意事项
2016-08-31 16:35
701 查看
成功调用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_store_result()返回NULL(因而没有结果集指针)时。在这种情况下,可调用mysql_field_count()来判定mysql_store_result()是否应生成非空结果。这样,客户端就能采取恰当的动作,而无需知道查询是否是SELECT(或类似SELECT的)语句。在这里给出的示例中,演示了完成它的方法。返回表示结果集中列数的无符号整数。
另一种可选的方法是,用mysql_errno(&mysql)替换mysql_field_count(&mysql)调用。在该情况下,无论语句是否是SELECT,你将直接从mysql_store_result()查找错误,而不是从mysql_field_count()的值进行推断。
通过调用mysql_error()或mysql_errno(),可测试是否出现了错误。
注意:
对于成功调用mysql_query()进行select语句的查询,即使查询的数据不存在(即rowcount=0),result也不为NULL。result为NULL的情况只是检测上一个查询是否是有返回值的语句。
范例:
转载请注明地址:http://www.cnblogs.com/fnlingnzb-learner/p/5826533.html
· 出现了malloc()故障(例如,如果结果集过大)。
· 无法读取数据(在连接上出现了错误)。
· 查询未返回数据(例如,它是INSERT、UPDATE或DELETE)。
通过调用mysql_field_count(),始终能检查语句是否应生成非空结果。如果mysql_field_count()返回0,结果为空,而且上一个查询是未返回值的语句(例如INSERT或DELETE)。如果mysql_field_count()返回非0值,语句应生成非空结果。关于这方面的示例,请参见mysql_field_count()函数介绍:
返回作用在连接上的最近查询的列数。该函数的正常使用是在mysql_store_result()返回NULL(因而没有结果集指针)时。在这种情况下,可调用mysql_field_count()来判定mysql_store_result()是否应生成非空结果。这样,客户端就能采取恰当的动作,而无需知道查询是否是SELECT(或类似SELECT的)语句。在这里给出的示例中,演示了完成它的方法。返回表示结果集中列数的无符号整数。
另一种可选的方法是,用mysql_errno(&mysql)替换mysql_field_count(&mysql)调用。在该情况下,无论语句是否是SELECT,你将直接从mysql_store_result()查找错误,而不是从mysql_field_count()的值进行推断。
通过调用mysql_error()或mysql_errno(),可测试是否出现了错误。
注意:
对于成功调用mysql_query()进行select语句的查询,即使查询的数据不存在(即rowcount=0),result也不为NULL。result为NULL的情况只是检测上一个查询是否是有返回值的语句。
范例:
MYSQL_RES *result; unsigned int num_fields; unsigned int num_rows; if (mysql_query(&mysql, query_string)) { // error } else // query succeeded, process any data returned by it { result = mysql_store_result(&mysql); if (result) // there are rows { num_fields = mysql_num_fields(result); // retrieve rows, then call mysql_free_result(result) } else // mysql_store_result() returned nothing; should it have? { if (mysql_field_count(&mysql) == 0) { // query does not return data // (it was not a SELECT) num_rows = mysql_affected_rows(&mysql); } else // mysql_store_result() should have returned data { fprintf(stderr, "Error: %s\n", mysql_error(&mysql)); } } }
转载请注明地址:http://www.cnblogs.com/fnlingnzb-learner/p/5826533.html
相关文章推荐
- mysql写存储过程的一些注意事项以及mysql的一些函数
- 为什么在mysql_query()返回成功后,mysql_store_result()有时会返回NULL
- 为什么在mysql_query()返回成功后,mysql_store_result()有时返回NULL?
- 探讨:C++中函数返回引用的注意事项
- C++ 与“类”有关的注意事项总结(四):静态类成员 和 静态成员函数
- 深入理解.Net中的内存释放,以及有关的注意事项
- MySQL 磁盘复制技术--DRBD:优缺点比较、注意事项以及最佳实践
- 有关STL中map的key是指针的情况分析和其他map使用注意点
- 浅谈MySQL存储引擎 InnoDB和MyISAM 以及行锁注意事项
- ext form的组件用法,以及提交返回数据的注意事项
- mysql count distinct null 使用注意事项
- MySQL 5.5 主从复制异步、半同步以及注意事项详解
- SuperMap Objects 中 soRecordset 使用,以及其他注意事项
- new与delete函数使用方法以及注意事项
- MYSQL5.6数据库ZIP安装以及VS中使用注意事项
- MySQL索引类型总结和使用技巧以及注意事项
- Delphi 中 函数参数中的 const 修饰符的本质以及注意事项
- 深入理解.Net中的内存释放,以及有关的注意事项
- 封装了envi函数的IDL发布程序的执行方法 以及注意事项
- SuperMap Objects 中 soRecordset 使用,以及其他注意事项