每天掌握一个Linux命令 - sqlite3

Linux 命令工具 sqlite3 使用指南

一、工具概述

sqlite3 是 SQLite 数据库的命令行工具,用于在 Linux 系统中直接操作 SQLite 数据库(轻量级、无服务器、嵌入式关系型数据库)。
核心特点

  • 无需安装数据库服务,直接通过命令行操作 .db 文件。
  • 支持 SQL92 标准,语法简洁,适合快速开发和小型项目。
  • 数据存储在单一文件中,方便移植和备份。

二、安装方式

1. 系统自带(多数 Linux 发行版)

直接在终端输入 sqlite3 命令,若提示版本信息则已安装:

sqlite3 --version  # 输出版本号(如 3.36.0)

2. 手动安装(以 Ubuntu/Debian 为例)

sudo apt update
sudo apt install sqlite3  # 安装命令行工具
sudo apt install libsqlite3-dev  # 安装开发库(可选,用于编译程序)

3. 源码编译(适用于自定义版本)

wget https://www.sqlite.org/src/tarball/sqlite.tar.gz?r=release  # 下载源码
tar -zxvf sqlite.tar.gz
cd sqlite
./configure
make && make install

三、核心功能

功能分类说明
数据库操作创建/打开数据库、删除表、备份数据库文件
数据操作增删改查(CRUD)、事务管理、聚合函数计算
元数据查看显示表结构、列出数据库中的表和索引、查看 SQL 语句执行计划
工具命令导出数据为 CSV/JSON、执行外部 SQL 文件、设置输出格式(表格/列模式)

四、基础用法

1. 连接/创建数据库

sqlite3 demo.db  # 若文件不存在,创建新数据库;存在则直接打开

退出数据库

.exit  -- 或 .quit

2. 执行 SQL 语句

sqlite3 交互模式下直接输入 SQL 命令(需以 ; 结尾):

-- 创建表
CREATE TABLE users (id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL,age INTEGER,email TEXT UNIQUE
);-- 插入数据
INSERT INTO users (name, age, email) VALUES ('Alice', 25, 'alice@example.com');-- 查询数据
SELECT * FROM users;

3. 常用元命令(以 . 开头,无需 ; 结尾)

元命令作用
.tables列出所有表
.schema [表名]显示表结构或指定表的建表语句
.headers on开启查询结果的列名显示
.mode column设置结果格式为列模式(默认是列表)
.output data.csv将查询结果输出到文件(需配合 .mode

五、进阶操作

1. 事务管理

BEGIN TRANSACTION;  -- 开始事务
INSERT INTO users (name, email) VALUES ('Bob', 'bob@example.com');
UPDATE users SET age = 30 WHERE name = 'Bob';
COMMIT;  -- 提交事务(或 ROLLBACK; 回滚)

2. 数据导出与导入

导出为 CSV 文件
.mode csv
.output users.csv
SELECT * FROM users;
从 SQL 文件导入数据
sqlite3 demo.db < data.sql  # 执行 data.sql 中的 SQL 语句

3. 执行计划分析

EXPLAIN QUERY PLAN SELECT * FROM users WHERE age > 25;  -- 查看查询优化策略

4. 数据库备份与恢复

# 备份数据库文件(直接复制 .db 文件)
cp demo.db demo_backup.db# 恢复(覆盖原文件,需确保数据库未被占用)
cp demo_backup.db demo.db

六、实战案例:学生成绩管理系统

场景:管理学生、课程、成绩数据

1. 创建数据库和表结构
CREATE DATABASE school;  -- SQLite 无需显式创建数据库,直接操作文件即可
.open school.db  -- 打开数据库文件CREATE TABLE students (sid INTEGER PRIMARY KEY,sname TEXT NOT NULL,age INTEGER,gender TEXT
);CREATE TABLE courses (cid INTEGER PRIMARY KEY,cname TEXT NOT NULL,credit INTEGER
);CREATE TABLE scores (sid INTEGER,cid INTEGER,score REAL,PRIMARY KEY (sid, cid),FOREIGN KEY (sid) REFERENCES students(sid),FOREIGN KEY (cid) REFERENCES courses(cid)
);
2. 插入测试数据
INSERT INTO students VALUES (1, 'Tom', 18, 'Male');
INSERT INTO courses VALUES (101, 'Math', 4);
INSERT INTO scores VALUES (1, 101, 85.5);
3. 查询平均成绩
.headers on
.mode column
SELECT s.sname, AVG(sc.score) AS avg_score
FROM students s
JOIN scores sc ON s.sid = sc.sid
GROUP BY s.sid;

七、注意事项

  1. 文件权限

    • 操作数据库文件时需注意读写权限,避免因权限不足导致操作失败(如 sqlite3 demo.db 时提示 Permission denied)。
  2. 事务安全

    • 高并发场景下需谨慎使用事务(SQLite 单文件模式在写入时会锁定数据库,适合低并发场景)。
  3. 数据类型

    • SQLite 采用 弱类型(列不强制约束数据类型),但建议遵循表定义的类型规范,避免逻辑错误。
  4. 文件大小

    • 单个 SQLite 文件最大支持约 140 TB(受限于文件系统),但实际应用中建议用于中小规模数据。
  5. 版本兼容

    • 低版本 SQLite 可能不支持部分 SQL 语法(如窗口函数),建议升级到最新版本(当前最新版本可通过 sqlite3 --version 查看)。

通过以上内容,可快速掌握 sqlite3 命令行工具的核心用法,适用于开发调试、小型数据管理等场景。如需处理大规模数据或高并发场景,建议结合应用层逻辑或迁移至 PostgreSQL、MySQL 等数据库。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/82675.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode:2160. 拆分数位后四位数字的最小和(python3解法,数学相关算法题)

难度&#xff1a;简单 给你一个四位 正 整数 num 。请你使用 num 中的 数位 &#xff0c;将 num 拆成两个新的整数 new1 和 new2 。new1 和 new2 中可以有 前导 0 &#xff0c;且 num 中 所有 数位都必须使用。 比方说&#xff0c;给你 num 2932 &#xff0c;你拥有的数位包括…

Python打卡第38天

浙大疏锦行 作业&#xff1a; 了解下cifar数据集&#xff0c;尝试获取其中一张图片 import torch import torch.nn as nn import torch.optim as optim from torch.utils.data import DataLoader , Dataset # DataLoader 是 PyTorch 中用于加载数据的工具 from torchvision im…

AI 数据采集实战指南:基于 Bright Data 快速获取招标讯息

AI 数据采集实战指南&#xff1a;基于Bright Data快速获取招标讯息 在招标行业中&#xff0c;快速、准确地获取招标公告、项目详情、投标截止日期和其他关键招标信息&#xff0c;是投标企业提高竞标成功率的核心竞争力。然而&#xff0c;招标信息往往分散在不同的平台和网页&a…

TCP 三次握手,第一次握手报文丢失会发生什么?

文章目录 RTO(Retransmission Timeout)注意 客户端想与服务端建立 TCP 连接时&#xff0c;先发送 SYN 报文&#xff0c;在这之后&#xff0c;如果客户端迟迟收不到服务端的 SYNACK 报文&#xff0c;就会触发「超时重传」机制&#xff0c;重新发送 SYN 报文&#xff0c;而且重传…

【DeepSeek论文精读】12. DeepSeek-Prover-V2: 通过强化学习实现子目标分解的形式化数学推理

欢迎关注[【AIGC论文精读】](https://blog.csdn.net/youcans/category_12321605.html&#xff09;原创作品 【DeepSeek论文精读】1. 从 DeepSeek LLM 到 DeepSeek R1 【DeepSeek论文精读】10. DeepSeek-Coder-V2: 突破闭源模型在代码智能领域的障碍 【DeepSeek论文精读】12. De…

第十一节:第一部分:正则表达式:应用案例、爬取信息、搜索替换

正则表达式介绍 String提供的正则表达式的方法的书写规则 正则表达式总结 正则表达式作用&#xff1a; 作用三&#xff1a;搜索替换 案例分析及代码&#xff08;图片解析&#xff09; 代码&#xff1a; 代码一&#xff1a;校验手机号和邮箱格式是否正确 package com.itheima.…

视频监控汇聚平台EasyCVR工业与安全监控:防爆摄像机的安全应用与注意事项

石油、化工、煤矿等行业存在易燃易爆气体、粉尘&#xff0c;普通监控设备易因电火花、高温引发爆炸火灾。随着工业规模扩大&#xff0c;安全生产监控需求激增&#xff0c;防爆摄像机成为保障安全的关键。加之国家法规与行业标准对危险环境监控设备要求严格&#xff0c;规范其应…

重学计算机网络之命令整理

配置权限相关 1.用户执行模式&#xff1a;查看网络设备状态信息 2.特权执行模式&#xff1a;查看和修改网络设备的状态和控制信息 3.全局配置模式&#xff1a;对整个网络设备进行全局性参数配置 4.接口配置模式&#xff1a;对网络设备的接口进行配置 enable #进入特权执行模式…

数据结构与算法Day3:绪论第三节抽象数据类型、算法及其描述

各位亲爱的读者&#xff0c;大家好&#xff01;今天博主给大家带来的内容是C语言数据结构与算法当中抽象数据类型、算法及其分析的相关知识。 一.抽象数据类型 抽象数据类型&#xff1a;指的是用户进行软件系统设计时从问题的数据模型中抽象出来的逻辑数据结构和逻辑数据结构上…

ABC 350

E. Toward 0 从大规模向小规模&#xff0c;用记忆化搜索&#xff0c;只需要分好类&#xff0c;有哪几种搜法。 期望实际上就是把每一种情况的答案答案都算出来&#xff0c;然后取个平均值 &#xff0c;并不困难。 f ( i ) [ f ( i / 6 ) f ( i / 5 ) f ( i / 4 ) f ( i / 3…

多相电机驱动控制学习(1)——基于双dq坐标系的六相/双三相PMSM驱动控制

1.引言 最近想学习一下多相电机。想从相对简单的开始吧&#xff0c;先学一个基于双dq的六相/双三相PMSM驱动控制&#xff08;考虑中性点隔离以及不隔离的情况&#xff0c;即考虑是否有零序电流回路&#xff09;&#xff0c;后面有时间再学学基于VSD的六相/双三相PMSM驱动控制。…

笔记: 在WPF中ContentElement 和 UIElement 的主要区别

一、目的&#xff1a;简要姐扫在WPF中ContentElement 和 UIElement 的主要区别 ContentElement 和 UIElement 是 WPF 中的两个基类&#xff0c;它们在功能和用途上有显著的区别。 二、主要区别 ContentElement 主要特点: • 没有视觉表示: ContentElement 本身不直接渲染任…

Android-Glide学习总结

Glide三级缓存​ 面试官 我看你简历里提到熟悉 Glide&#xff0c;能聊聊它的缓存机制吗&#xff1f;比如加载图片的时候&#xff0c;Glide 是怎么决定从内存还是磁盘读取的&#xff1f; ​你​ 哦&#xff0c;Glide 的缓存机制是吧&#xff1f;嗯&#xff0c;这个我之前在做项…

安卓证书的申请(保姆级图文)

目录 确认安装了对应版本的jdk生成证书文件1. -genkey2. -alias test_certalias3. -keyalg RSA4. -keysize 20485. -validity 365006. -keystore test_cert.keystore 查看证书内容总结 欢迎关注 『发现你走远了』 博客&#xff0c;持续更新中 欢迎关注 『发现你走远了』 博客&a…

Unity性能优化

SetPass calls表示在当前摄像机的渲染过程中&#xff0c;Unity切换着色器通道&#xff08;Shader Pass&#xff09;来渲染游戏对象的次数。一个着色器&#xff08;Shader&#xff09;可以包含多个着色器通道&#xff0c;每个着色器通道可以通过不同的方式来渲染游戏对象。但每次…

Python+AI Agent:解锁MCP Servers的智能潜力

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storms…

uni-app学习笔记十五-vue3页面生命周期(一)

页面生命周期概览 vue3页面生命周期如下图所示&#xff1a; onLoad 此时页面还未显示&#xff0c;没有开始进入的转场动画&#xff0c;页面dom还不存在。 所以这里不能直接操作dom&#xff08;可以修改data&#xff0c;因为vue框架会等待dom准备后再更新界面&#xff09;&am…

【排序算法】快速排序详解--附详细流程代码

快速排序算法 介绍 快速排序&#xff08;Quick Sort&#xff09;是一种高效的分治排序算法&#xff0c;由英国计算机科学家 Tony Hoare 于 1960 年提出。它是实际应用中最常用的排序算法之一。快速排序的基本思想是&#xff1a;选择一个"基准"&#xff08;pivot&am…

【监控】Prometheus中的告警机制介绍

prometheus实战之三&#xff1a;告警规则_验证prometheus告警规则-CSDN博客 Prometheus是一款开源的系统监控和告警工具&#xff0c;其告警功能是保障系统稳定运行的重要部分。以下将从告警的整体架构、核心概念、规则配置以及具体的通知流程等方面对Prometheus中的告警进行介…

53、用例(Use Case)详解

1. 定义与核心概念 用例&#xff08;Use Case&#xff09; 是软件工程中用于描述系统功能需求的核心工具&#xff0c;它通过结构化的方式定义系统与外部参与者&#xff08;用户、其他系统&#xff09;之间的交互行为&#xff0c;以实现具体的业务目标。用例强调从用户视角出发…