sqlite 数据类型是一个用来指定任何对象的数据类型的属性。sqlite 中的每一列,每个变量和表达式都有相关的数据类型。
您可以在创建表的同时使用这些数据类型。sqlite 使用一个更普遍的动态类型系统。在 sqlite 中,值的数据类型与值本身是相关的,而不是与它的容器相关。
每个存储在 sqlite 数据库中的值都具有以下存储类之一:
存储类
描述
null
值是一个 null 值。
integer
值是一个带符号的整数,根据值的大小存储在 1、2、3、4、6 或 8 字节中。
real
值是一个浮点值,存储为 8 字节的 ieee 浮点数字。
text
值是一个文本字符串,使用数据库编码(utf-8、utf-16be 或 utf-16le)存储。
blob
值是一个 blob 数据,完全根据它的输入存储。
sqlite 的存储类稍微比数据类型更普遍。integer 存储类,例如,包含 6 种不同的不同长度的整数数据类型。
sqlite 支持列上的类型 affinity 概念。任何列仍然可以存储任何类型的数据,但列的首选存储类是它的 affinity。在 sqlite3 数据库中,每个表的列分配为以下类型的 affinity 之一:
affinity
该列使用存储类 null、text 或 blob 存储所有数据。
numeric
该列可以包含使用所有五个存储类的值。
与带有 numeric affinity 的列相同,在 cast 表达式中带有异常。
与带有 numeric affinity 的列相似,不同的是,它会强制把整数值转换为浮点表示。
none
带有 affinity none 的列,不会优先使用哪个存储类,也不会尝试把数据从一个存储类强制转换为另一个存储类。
下表列出了当创建 sqlite3 表时可使用的各种数据类型名称,同时也显示了相应的应用 affinity:
数据类型
int
tinyint
smallint
mediumint
bigint
unsigned big int
int2
int8
character(20)
varchar(255)
varying character(255)
nchar(55)
native character(70)
nvarchar(100)
clob
no datatype specified
double
double precision
float
decimal(10,5)
boolean
date
datetime
sqlite 没有单独的 boolean 存储类。相反,布尔值被存储为整数 0(false)和 1(true)。
sqlite 没有一个单独的用于存储日期和/或时间的存储类,但 sqlite 能够把日期和时间存储为 text、real 或 integer 值。
日期格式
格式为 "yyyy-mm-dd hh:mm:ss.sss" 的日期。
从公元前 4714 年 11 月 24 日格林尼治时间的正午开始算起的天数。
从 1970-01-01 00:00:00 utc 算起的秒数。
您可以以任何上述格式来存储日期和时间,并且可以使用内置的日期和时间函数来自由转换不同格式。