SQLite建表语句示例(含所有数据类型、索引、自增主键、唯一索引)

下面是一个示例,展示如何创建一个用户信息表。

包含 SQLite 支持的所有数据类型,同时设置主键为自增、一个字段为唯一索引,以及另一个字段为普通索引:

sql 复制代码
-- 创建用户信息表
CREATE TABLE user_info (
    id INTEGER PRIMARY KEY AUTOINCREMENT,  -- 自增主键
    username TEXT UNIQUE,                  -- 唯一索引
    email TEXT,                            -- 普通索引
    age INTEGER,
    balance REAL,
    profile BLOB,
    is_active NUMERIC
);

-- 为 email 字段创建普通索引
CREATE INDEX idx_user_info_email ON user_info(email);

说明

id INTEGER PRIMARY KEY AUTOINCREMENT : id 是自增主键,自动生成唯一值。

username TEXT UNIQUE : username 字段是唯一索引,确保每个用户名在表中是唯一的。

email TEXT : email 字段将有一个普通索引,以加快基于电子邮件的查询。

age INTEGER: 用于存储整数类型的数据,如年龄。

balance REAL: 用于存储浮点数,如账户余额。

profile BLOB: 用于存储二进制数据,如用户的图片或其他文件。

is_active NUMERIC: 用于存储布尔值或其他数值类型,表示用户是否活跃。

通过这种表结构,你可以有效地利用 SQLite 的数据类型和索引功能来管理用户信息。

相关推荐
betazhou44 分钟前
有没有 MariaDB 5.5.56 对应 MySQL CONNECTION_CONTROL 插件
linux·数据库·mysql·oracle·mariadb
Elohim8151 小时前
数据库SQLite基础
数据库·sqlite
TDengine (老段)1 小时前
TDengine 支持的平台汇总
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
大熊猫侯佩2 小时前
由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(四)
数据库·swiftui·apple watch
想用offer打牌2 小时前
面试官问:Redis和MySQL数据一致,为什么还需要MySQL?🤠
数据库·redis·mysql
chen.@-@2 小时前
后端下载限速(redis记录实时并发,bucket4j动态限速)
数据库·redis·缓存
王小小鸭3 小时前
【Oracle APEX开发小技巧12】
数据库·oracle
噼里啪啦啦.3 小时前
Spring事务和事务传播机制
数据库·sql·spring
搬码红绿灯3 小时前
MySQL主从复制深度解析:原理、架构与实战部署指南
数据库·mysql·架构
呼拉拉呼拉3 小时前
Redis高可用架构
数据库·redis·架构·高可用架构