首页 > 技术文章 > Qt: QSqlRecord字段值为null时注意事项

roadbike 2016-07-21 19:49 原文

QSqlRecord在对应字段值为null时,QSqlRecord::value返回的QVariant是有效但为null(相当于使用QVariant(Type type)构造的),所以此时做对应类型的转换是可以成功的(如toInt)。。。转换后null结果会变成一个具体数值(如0),这样很可能导致程序出现错误(通常用-1作为无效值,0可能就会让实际为null的情况误入正常流程),使用QSqlRecord::value前对于可能为null的字段记得先调QSqlRecord::isNull判断下或者也可以调QVariant::isNull判断。

推荐阅读