最近用Linux c/c++写一个项目,自己封装了一个MySQL控制类,但是每次在循环的时候都出现异常退出而不能正常赋值数据集的问题。索性厚着脸皮打扰了很多开发让帮忙查问题,还好最终把问题定位到了。由于读取到的MYSQL_ROW类型数据是NULL,导致在for循环创造数据集二维数组的时候意外跳出内层循环,导致赋值补全。
因此大家一定要在用mysql c api调用的时候保证db中创建的字段不能有NULL,必须对每个字段设定默认值。
附送一个代码案例,不仅在mysql读取中有这个问题,普通的for循环中NULL赋值也会造成循环体异常退出。
01 | #include<stdio.h> |
02 | #include<iostream> |
03 | using namespace std; |
04 |
05 | int main(){ |
06 | char *arr1[3]={ "AA" , "BB" , "CC" }; |
07 | char *arr2[3]={ "AA" ,NULL, "CC" }; |
08 | for ( int i=0;i<3;i++){ |
09 | cout<<*arr1[i]<<endl; |
10 | } |
11 | for ( int i=0;i<3;i++){ |
12 | cout<<arr2[i]<<endl; |
13 | } |
14 | return 0; |
15 | } |
输出:
1 | A |
2 | B |
3 | C |
4 | AA |
5 |
6 |
7 | 运行 成功 (总计时间: 203毫秒) |
此时会注意到arr2字符串数组遇到NULL而导致CC"没输出出来。