SQLite 数据类型概述

SQLite 数据类型概述

SQLite 采用动态类型系统,数据类型由值本身而非列定义决定。列的类型声明仅为"类型亲和性"(Type Affinity),用于指导数据存储方式。以下是 SQLite 支持的核心数据类型和亲和性分类:


存储类(Storage Classes)

SQLite 实际存储数据时使用以下五种存储类:

  1. NULL

    表示空值,与任何其他类型均不相同。

  2. INTEGER

    带符号整数,根据值大小以 1、2、3、4、6 或 8 字节存储。

  3. REAL

    浮点数,以 8 字节 IEEE 754 格式存储。

  4. TEXT

    字符串,使用数据库编码(UTF-8、UTF-16BE 或 UTF-16LE)存储。

  5. BLOB

    二进制数据,完全按输入存储,不做任何转换。


类型亲和性(Type Affinity)

列定义中的类型名称会被映射为以下五种亲和性之一,影响数据插入时的转换规则:

  1. INTEGER

    匹配 INTTINYINTBIGINT 等含 "INT" 关键字的类型声明。

  2. REAL

    匹配 REALFLOATDOUBLE 等浮点类型声明。

  3. TEXT

    匹配 CHARVARCHARTEXT 等字符串类型声明。

  4. BLOB

    仅匹配明确声明为 BLOB 或无类型的情况。

  5. NUMERIC

    默认亲和性,匹配其他类型名(如 BOOLEANDATE),尝试优先转换为 INTEGER 或 REAL。


类型转换规则

插入数据时,SQLite 按以下规则处理类型亲和性:

  • INTEGER 亲和性

    尝试将值转换为 INTEGER。若 TEXT 格式为整数或 REAL 无小数部分,则转换;否则存储为 REAL 或 TEXT。

  • REAL 亲和性

    尝试转换为 REAL,失败时存储为 TEXT。

  • TEXT 亲和性

    将值转换为 TEXT 格式。

  • BLOB 亲和性

    不进行任何转换。

  • NUMERIC 亲和性

    优先尝试 INTEGER,其次 REAL,最后 TEXT 或 BLOB。


示例代码

创建表时类型声明的亲和性映射示例:

sql 复制代码
CREATE TABLE example (
    col1 INTEGER,      -- INTEGER 亲和性
    col2 REAL,         -- REAL 亲和性
    col3 TEXT,         -- TEXT 亲和性
    col4 BLOB,         -- BLOB 亲和性
    col5 BOOLEAN       -- NUMERIC 亲和性(非标准类型名)
);

插入数据时的自动转换:

sql 复制代码
INSERT INTO example VALUES 
    (123, 45.67, 'hello', x'0102', TRUE);  -- BOOLEAN 存储为 INTEGER 1

注意事项

  1. 动态类型灵活性

    同一列可存储不同类型的数据,例如 INTEGER 列可存储 TEXT "123"。

  2. 日期和时间

    SQLite 无内置日期类型,通常以 TEXT(ISO8601)、REAL(Julian Day)或 INTEGER(Unix Time)存储。

  3. 布尔值

    使用 01 表示,亲和性为 NUMERIC 或 INTEGER。

相关推荐
jiunian_cn1 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
冉冰学姐1 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
C雨后彩虹1 小时前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
知识分享小能手2 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
java1234_小锋2 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试
2501_944525543 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐3 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法
Filotimo_3 小时前
Tomcat的概念
java·tomcat
踩坑小念3 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀