SQLite中sqlite3_column_value()的返回值

sqlite3_column_value()的返回对象是一个 unprotected sqlite3_value 对象.一个不受保护的sqlite3_value object可能只能用于 sqlite3_bind_value()sqlite3_result_value().如果一个unprotected sqlite3_value 对象( sqlite3_column_value()函数的返回值) 被用在其他地方,包括调用如 sqlite3_value_int(), sqlite3_value_text(), 或sqlite3_value_bytes()之类的函数,它的行为是不可预测的。

这些函数尝试把值转化成正确的类型。比如说,对储存在数据库中,值类型为FLOAT的字段,通过但是作为text类型被select出来。sqlite3_snprintf()将自动转换这个数值。下表详细地说明了转化过程。

内部类型(Internal Type请求类型               Requested Type转化(Conversion
NULLINTEGER值为 0
NULLFLOAT值为 0.0
NULLTEXT值为 NULL指针
NULLBLOB值为 NULL指针
INTEGERFLOAT从integer 转化为float
INTEGERTEXT  integer渲染成ASCII
INTEGERBLOB INTEGER->TEXT转换过程一样
FLOATINTEGER从float 转化为integer
FLOATTEXT  FLOAT渲染成ASCII
FLOATBLOBFLOAT->TEXT转换过程一样
TEXTINTEGER使用 atoi()
TEXTFLOAT使用 atof()
TEXTBLOB不做改变
BLOBINTEGER转化为TEXT 然后使用 atoi()
BLOBFLOAT转化为TEXT 然后使用 atof()
BLOBTEXT如果需要的话,添加0作为终结符

上表引用C函数库的atoi() 和atof()。实际上,SQLite不会使用这些函数,SQLite有自己跟这些函数等价的转换函数。使用atoi() 和atof()是为了让上表更简短,因为大部分的C程序员对他们都很熟悉。

    原文作者:sqlite
    原文地址: https://www.cnblogs.com/kissazi2/p/3162185.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞