SQLite3 中列(变量)的特殊属性

在 SQLite3 中,列的特殊属性通常通过约束(Constraints)和数据类型修饰符来定义。这些属性可以在创建表时指定,用于限制数据的完整性或定义特殊行为。以下是 SQLite3 支持的主要特殊属性及其说明:

1. 主键约束(PRIMARY KEY)

  • 功能:确保列中的值唯一且不为 NULL,通常用于标识表中的每一行。

  • 示例

    sql 复制代码
    CREATE TABLE users (
        id INTEGER PRIMARY KEY,  -- 自增主键(见 AUTOINCREMENT)
        name TEXT NOT NULL
    );
  • 特性

    • 若未显式指定值,SQLite 会自动分配一个唯一的整数(ROWID)。
    • 一个表只能有一个主键,但主键可以由多个列组成(复合主键)。

2. 自增属性(AUTOINCREMENT)

  • 功能 :仅用于 INTEGER PRIMARY KEY,确保值严格递增且不会被重用(即使行被删除)。

  • 示例

    sql 复制代码
    CREATE TABLE logs (
        id INTEGER PRIMARY KEY AUTOINCREMENT,  -- 自增且不重用值
        message TEXT
    );
  • 注意

    • 不使用 AUTOINCREMENT 时,SQLite 可能会重用已删除的 ID 值(性能更佳)。
    • AUTOINCREMENT 会增加额外开销,仅在需要严格递增时使用。

3. 唯一约束(UNIQUE)

  • 功能:确保列中的所有值都是唯一的,但允许有一个 NULL 值。

  • 示例

    sql 复制代码
    CREATE TABLE emails (
        user_id INTEGER PRIMARY KEY,
        email TEXT UNIQUE  -- 每个邮箱必须唯一
    );

4. 非空约束(NOT NULL)

  • 功能:禁止列中插入 NULL 值。

  • 示例

    sql 复制代码
    CREATE TABLE products (
        id INTEGER PRIMARY KEY,
        name TEXT NOT NULL,  -- 名称不能为空
        price REAL
    );

5. 默认值(DEFAULT)

  • 功能:当插入时未提供值,则使用预设的默认值。

  • 示例

    sql 复制代码
    CREATE TABLE tasks (
        id INTEGER PRIMARY KEY,
        status TEXT DEFAULT 'pending',  -- 默认状态为 "pending"
        created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP  -- 默认时间为当前时间
    );

6. CHECK 约束

  • 功能:自定义条件,确保插入或更新的值满足特定表达式。

  • 示例

    sql 复制代码
    CREATE TABLE employees (
        id INTEGER PRIMARY KEY,
        salary REAL CHECK (salary > 0),  -- 工资必须为正数
        age INTEGER CHECK (age >= 18)    -- 年龄必须 >= 18
    );

7. 外键约束(FOREIGN KEY)

  • 功能:建立表间关联,确保引用的值存在于关联表中。

  • 示例

    sql 复制代码
    CREATE TABLE orders (
        order_id INTEGER PRIMARY KEY,
        user_id INTEGER,
        FOREIGN KEY (user_id) REFERENCES users(id)  -- user_id 必须存在于 users 表的 id 列中
    );
  • 特性

    • 需要通过 PRAGMA foreign_keys = ON; 启用外键约束。
    • 可配合 ON DELETEON UPDATE 子句定义级联操作(如 CASCADESET NULL)。

8. 索引(INDEX)

  • 功能:加速查询,但不属于严格的约束。

  • 示例

    sql 复制代码
    CREATE INDEX idx_emails ON emails(email);  -- 为 email 列创建索引

9. 冲突处理

  • 功能 :当违反约束时的默认行为,可通过 ON CONFLICT 子句指定。

  • 选项

    • ROLLBACK:回滚事务。
    • ABORT:中止当前操作(默认)。
    • REPLACE:替换已有记录。
    • IGNORE:忽略冲突。
  • 示例

    sql 复制代码
    INSERT OR REPLACE INTO emails (user_id, email) VALUES (1, 'new@example.com');

10. 自动时间戳

  • 功能 :利用 DEFAULT CURRENT_TIMESTAMP 自动记录时间。

  • 示例

    sql 复制代码
    CREATE TABLE sessions (
        id INTEGER PRIMARY KEY,
        created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
        updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP  -- 更新时自动刷新
    );

总结

属性 作用
PRIMARY KEY 确保唯一性和非空性,通常作为行标识符。
AUTOINCREMENT 强制整数主键严格递增且不重用值。
UNIQUE 确保列值唯一(允许一个 NULL)。
NOT NULL 禁止插入 NULL 值。
DEFAULT value 未提供值时使用默认值。
CHECK (expr) 自定义约束条件。
FOREIGN KEY 建立表间引用关系。
INDEX 加速查询(非约束)。
ON CONFLICT 定义约束冲突时的处理策略。

使用建议

  • 主键选择 :优先使用 INTEGER PRIMARY KEY,性能最佳。仅在必要时添加 AUTOINCREMENT
  • 外键约束 :启用外键约束(PRAGMA foreign_keys = ON)以维护数据完整性。
  • CHECK 约束:用于业务规则(如年龄范围、金额限制),但避免复杂表达式以保持性能。
相关推荐
码路飞32 分钟前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
SimonKing1 小时前
OpenCode AI编程助手如何添加Skills,优化项目!
java·后端·程序员
Seven973 小时前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德14 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆16 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌18 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊19 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang19 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
Ray Liang21 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Java水解21 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端