Apr18

【原创】c/c++读取MySQL中空字段的注意事项

Author: leeon  Click: 7921   Date: 2012.04.18 @ 19:20:28 pm Category: c/c++

最近用Linux c/c++写一个项目,自己封装了一个MySQL控制类,但是每次在循环的时候都出现异常退出而不能正常赋值数据集的问题。索性厚着脸皮打扰了很多开发让帮忙查问题,还好最终把问题定位到了。由于读取到的MYSQL_ROW类型数据是NULL,导致在for循环创造数据集二维数组的时候意外跳出内层循环,导致赋值补全。

因此大家一定要在用mysql c api调用的时候保证db中创建的字段不能有NULL,必须对每个字段设定默认值。

附送一个代码案例,不仅在mysql读取中有这个问题,普通的for循环中NULL赋值也会造成循环体异常退出。


#include<stdio.h>
#include<iostream>
using namespace std;

int main(){
char *arr1[3]={"AA","BB","CC"};
char *arr2[3]={"AA",NULL,"CC"};
for(int i=0;i<3;i++){
cout<<*arr1[i]<<endl;
}
for(int i=0;i<3;i++){
cout<<arr2[i]<<endl;
}
return 0;
}

输出:


A
B
C
AA


运行 成功 (总计时间: 203毫秒)

此时会注意到arr2字符串数组遇到NULL而导致CC"没输出出来。



TAG:   c c++ mysql null

    评论
    • 提交

    分类

    标签

    归档

    最新评论

    Abyss在00:04:28评论了
    Linux中ramdisk,tmpfs,ramfs的介绍与性能测试
    shallwe99在10:21:17评论了
    【原创】如何在微信小程序开发中正确的使用vant ui组件
    默一在09:04:53评论了
    Berkeley DB 由浅入深【转自架构师杨建】
    Memory在14:09:22评论了
    【原创】最佳PHP框架选择(phalcon,yaf,laravel,thinkphp,yii)
    leo在17:57:04评论了
    shell中使用while循环ssh的注意事项

    我看过的书

    链接

    其他

    访问本站种子 本站平均热度:8823 c° 本站链接数:1 个 本站标签数:464 个 本站被评论次数:94 次