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
NULL INTEGER 值为 0
NULL FLOAT 值为 0.0
NULL TEXT 值为 NULL指针
NULL BLOB 值为 NULL指针
INTEGER FLOAT 从integer 转化为float
INTEGER TEXT   integer渲染成ASCII
INTEGER BLOB  INTEGER->TEXT转换过程一样
FLOAT INTEGER 从float 转化为integer
FLOAT TEXT   FLOAT渲染成ASCII
FLOAT BLOB FLOAT->TEXT转换过程一样
TEXT INTEGER 使用 atoi()
TEXT FLOAT 使用 atof()
TEXT BLOB 不做改变
BLOB INTEGER 转化为TEXT 然后使用 atoi()
BLOB FLOAT 转化为TEXT 然后使用 atof()
BLOB TEXT 如果需要的话,添加0作为终结符

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

本文转自陈哈哈博客园博客,原文链接http://www.cnblogs.com/kissazi2/p/3162185.html如需转载请自行联系原作者

kissazi2
相关文章
|
7天前
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
|
7天前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
|
2月前
|
人工智能 小程序 Java
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
本文介绍了一款名为PyWxDump的开源工具,它可以获取微信账户信息、解密SQLite数据库以查看和备份聊天记录。此工具适用于已登录电脑版微信的用户,通过GitHub下载后简单几步即可操作。适合对数据恢复感兴趣的开发者,但请注意合法合规使用并尊重隐私。
206 2
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
|
9天前
|
SQL 数据库 数据库管理
SQLite 创建数据库
SQLite 的 sqlite3 命令被用来创建新的 SQLite 数据库。您不需要任何特殊的权限即可创建一个数据。
13 0
|
10天前
|
JSON NoSQL 数据库
和SQLite数据库对应的NoSQL数据库:TinyDB的详细使用(python3经典编程案例)
该文章详细介绍了TinyDB这一轻量级NoSQL数据库的使用方法,包括如何在Python3环境中安装、创建数据库、插入数据、查询、更新以及删除记录等操作,并提供了多个编程案例。
24 0
|
2月前
|
SQL 存储 小程序
【教程】navicat配合HTTP通道远程连接SQLite数据库
本文介绍了如何通过 Navicat Premium 工具配合 n_tunnel_sqlite.php 和 HTTP 通道远程连接服务器上的 SQLite 数据库。SQLite 是一种自给自足的、无服务器的 SQL 数据库引擎,由于其端口未对外开放,直接使用 Navicat 进行远程连接不可行。文章详细记录了使用 HTTP 通道实现远程连接的过程,包括定位本地 `ntunnel_sqlite.php` 文件,将其上传至服务器,并通过 Navicat 配置 HTTP 通道连接 SQLite 数据库的具体步骤。
53 0
【教程】navicat配合HTTP通道远程连接SQLite数据库
|
2月前
|
关系型数据库 Java MySQL
C#winform中使用SQLite数据库
C#winform中使用SQLite数据库
65 3
C#winform中使用SQLite数据库
|
2月前
|
Java 数据库连接 数据库
java系列之~如何给sqlite数据库添加表
这篇文章介绍了如何在Java中使用SQLite JDBC驱动来连接SQLite数据库,并提供了示例代码来演示如何创建一个新的数据库表。
|
2月前
|
SQL 存储 数据库
SQLite数据库
【8月更文挑战第21天】SQLite数据库
36 3
|
2月前
|
存储 数据库 数据库管理
SQLite数据库的备份
【8月更文挑战第20天】SQLite数据库的备份
121 1
下一篇
无影云桌面