当前位置: 首页 > news >正文

sqlite3 命令行工具详细介绍

在这里插入图片描述

一、启动与退出

  1. 启动数据库连接

    sqlite3 [database_file]  # 打开/创建数据库文件(如 test.db)
    sqlite3                  # 启动临时内存数据库 (:memory:)
    sqlite3 :memory:         # 显式启动内存数据库
    
    • 文件不存在时自动创建
    • 不指定文件名则使用临时内存数据库(关闭后消失)
  2. 退出 CLI

    .exit
    .quit
    Ctrl + D (Linux/macOS)
    Ctrl + C (Windows)
    

二、数据库与文件操作

命令说明示例
.open [FILENAME]打开/切换数据库.open backup.db
.backup ?DB? FILE在线备份数据库.backup main backup_2023.db
.restore ?DB? FILE从文件恢复数据库.restore main backup_2023.db
.dump ?TABLE?导出数据库为 SQL 脚本.dump > full.sql
.dump users > users.sql
.read FILENAME执行 SQL 脚本文件.read import_data.sql
.save FILE保存内存数据库到文件.save mem_backup.db

三、元数据查询

命令说明
.databases显示所有附加数据库
.tables ?PATTERN?列出表(支持通配符)
.schema ?TABLE?显示表结构(CREATE语句)
.indexes ?TABLE?列出索引
.fullschema显示完整 schema(包括隐藏信息)

四、数据操作与导入导出

  1. CSV 导入导出

    -- 设置 CSV 模式
    .mode csv
    .headers on   -- 导出时包含列名-- 导入 CSV
    .import users.csv users  -- 文件 → 表-- 导出 CSV
    .output users_export.csv
    SELECT * FROM users;
    .output stdout           -- 恢复输出到终端
    
  2. 其他格式

    .mode list       -- 自定义分隔符 (默认 '|')
    .mode insert     -- 生成 INSERT 语句
    .mode json       -- JSON 格式输出
    .separator ","   -- 设置分隔符(如 CSV)
    .nullvalue NULL  -- 指定 NULL 的显示值
    

五、查询输出格式化

命令效果示例输出
.mode list竖线分隔1|Alice|30
.mode csvCSV 格式"1","Alice","30"
.mode column表格对齐1 Alice 30
.mode box表格+边框┌──┬───────┬──┐
│1 │ Alice │30│
.mode jsonJSON 数组[{"id":1,"name":"Alice","age":30}]
.headers on/off显示/隐藏列名
.width NUM1 NUM2设置列宽.width 5 10 4
.timer on/off显示查询耗时Run Time: real 0.002 user 0.000000 sys 0.000000

六、实用功能

命令说明
.show显示当前所有设置
.stats on/off开关性能统计
.timefmt FORMAT设置日期格式
.shell CMD执行系统命令
.system CMD同上(别名)
.prompt MAIN CONTINUE自定义提示符

七、高级操作

  1. 附加多个数据库

    ATTACH DATABASE 'aux.db' AS aux;
    SELECT * FROM main.users JOIN aux.orders ...;
    .databases  -- 查看附加数据库
    
  2. 执行 PRAGMA 配置

    PRAGMA journal_mode=WAL;    -- 启用 WAL 模式
    PRAGMA synchronous=NORMAL;  -- 平衡性能与安全
    PRAGMA foreign_keys=ON;     -- 启用外键约束
    
  3. 事务控制

    BEGIN TRANSACTION;
    UPDATE accounts SET balance = balance - 100 WHERE id=1;
    UPDATE accounts SET balance = balance + 100 WHERE id=2;
    COMMIT;  -- 或 ROLLBACK
    

八、快捷示例场景

场景 1:从 CSV 创建新表并导入

sqlite3 finance.db  # 创建数据库
-- 创建表
CREATE TABLE transactions (id INTEGER PRIMARY KEY,date TEXT,amount REAL,description TEXT
);-- 导入 CSV
.mode csv
.import transactions.csv transactions-- 验证数据
SELECT count(*) FROM transactions;

场景 2:备份与恢复

# 完整备份
sqlite3 production.db ".backup main backup_20231001.db"# 恢复数据库
sqlite3 restored.db ".restore main backup_20231001.db"

九、注意事项

  1. 命令分类

    • 点命令 (.):以 . 开头(如 .tables),不需分号结尾
    • SQL 语句:标准 SQL(SELECT, CREATE 等),必须用分号 ; 结尾
  2. 特殊字符转义
    在字符串中使用单引号时需转义:

    INSERT INTO logs (message) VALUES ('It''s a test');
    
  3. 资源限制
    查看限制:PRAGMA compile_options;
    常见限制:SQLITE_MAX_LENGTH=1,000,000,000 (字符串/Blob最大长度)


掌握这些命令后,您可通过 sqlite3 CLI 高效完成日常数据库管理任务!

http://www.lqws.cn/news/112663.html

相关文章:

  • 蓝桥杯_DS18B20温度传感器---新手入门级别超级详细解析
  • 【自动思考记忆系统】demo (Java版)
  • 50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Dad Jokes(冷笑话卡片)
  • LangChain学习系列之LangChain4j介绍
  • vue入门环境搭建及demo运行
  • oauth2.0
  • 【Linux】进程虚拟地址空间详解
  • 嵌入式复习小练
  • 【散刷】二叉树基础OJ题(二)
  • 0518蚂蚁暑期实习上机考试题3:小红的字符串构造
  • 基于netmiko模块实现支持SSH or Telnet的多线程多厂商网络设备自动化巡检脚本
  • 采摘机器人项目
  • 北京大学肖臻老师《区块链技术与应用》公开课:07-BTC-挖矿难度
  • 【学习笔记】深度学习-过拟合解决方案
  • 光伏功率预测新突破:TCN-ECANet-GRU混合模型详解与复现
  • 前端(vue)学习笔记(CLASS 7):vuex
  • C++学者给您讲数学之——数列
  • 【Spring AI 1.0.0】Spring AI 1.0.0框架快速入门(1)——Chat Client API
  • Leetcode-7 寻找用户推荐人
  • C++中锁与原子操作的区别及取舍策略
  • 深入理解 JSX:React 的核心语法
  • JSON to Excel 3.0.0 版本发布 - 从Excel插件到Web应用的转变
  • 手撕HashMap!(JDK7版本)
  • 张雪峰为9岁女儿申请40个左右商标!
  • java反序列化:CC5利用链解析
  • Python应用continue关键字初解
  • Python数据分析及可视化中常用的6个库及函数(二)
  • BGP/MPLS IP VPN跨域解决方案
  • 《Pytorch深度学习实践》ch5-Logistic回归
  • ollama的安装及加速下载技巧