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

每天掌握一个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 等数据库。

相关文章:

每天掌握一个Linux命令 - sqlite3

Linux 命令工具 sqlite3 使用指南 一、工具概述 sqlite3 是 SQLite 数据库的命令行工具&#xff0c;用于在 Linux 系统中直接操作 SQLite 数据库&#xff08;轻量级、无服务器、嵌入式关系型数据库&#xff09;。 核心特点&#xff1a; 无需安装数据库服务&#xff0c;直接通…...

程序环境与预处理

一、程序的翻译环境和执行环境 翻译环境&#xff1a;将源代码转化为可执行的机器指令 执行环境&#xff1a;执行代码 1、翻译环境 流程&#xff1a; 二、运行环境 程序执行过程&#xff1a; 三、预编译阶段 1、预定义符号 __FILE__ //进行编译的原文件名 __LINE__ //文…...

RT Thread Nano V4.1.1 rtconfig.h 注释 Configuration Wizard 格式

rtcomfig.h 以下是对 [rtconfig.h](file://c:\Users\admin\Downloads\rtthread-nano-master\rt-thread\bsp\stm32f407-msh\RT-Thread\rtconfig.h) 文件中每一个配置项的详细注释说明: 基本配置(Basic Configuration) [RT_THREAD_PRIORITY_MAX](file://c:\Users\admin\Downl…...

《Java 单例模式:从类加载机制到高并发设计的深度技术剖析》

【作者简介】“琢磨先生”--资深系统架构师、985高校计算机硕士&#xff0c;长期从事大中型软件开发和技术研究&#xff0c;每天分享Java硬核知识和主流工程技术&#xff0c;欢迎点赞收藏&#xff01; 一、单例模式的核心概念与设计目标 在软件开发中&#xff0c;我们经常会遇…...

JSONP跨域原理全解析

JSONP&#xff08;JSON with Padding&#xff09;是一种绕过浏览器同源策略限制、实现跨域数据请求的“hack”式方案。其核心原理和流程如下&#xff1a; 同源策略限制 浏览器为了安全&#xff0c;只允许页面从与当前页面相同协议、域名、端口的服务器加载数据。而 <script&…...

【MySQL】第11节|MySQL 8.0 主从复制原理分析与实战(一)

一、MySQL主从复制基础 1. 核心概念 定义&#xff1a; MySQL主从复制是将主库&#xff08;Source/Master&#xff09;的数据变更同步到一个或多个从库&#xff08;Replica/Slave&#xff09;的机制&#xff0c;默认采用异步复制&#xff0c;支持全库、指定库或表的同步。 角…...

全志F1c200开发笔记——移植根文件系统

1.下载buildroot Index of /downloads/ 使用2018.02.11版本 直链下载 https://buildroot.org/downloads/buildroot-2018.02.11.tar.gz 2.配置 进入buildroot压缩包目录下&#xff0c;使用命令解压并进入工作目录 tar -xf buildroot-2018.02.11.tar.gz cd buildroot-2018.…...

[yolov11改进系列]基于yolov11引入自注意力与卷积混合模块ACmix提高FPS+检测效率python源码+训练源码

[ACmix的框架原理] 1.1 ACMix的基本原理 ACmix是一种混合模型&#xff0c;结合了自注意力机制和卷积运算的优势。它的核心思想是&#xff0c;传统卷积操作和自注意力模块的大部分计算都可以通过1x1的卷积来实现。ACmix首先使用1x1卷积对输入特征图进行投影&#xff0c;生成一组…...

Java NIO编程:构建高性能网络应用

1.Java NIO 核心概念与架构 1. 传统 BIO 与 NIO 的对比 特性 BIO (Blocking I/O) NIO (Non-blocking I/O) I/O 模型 阻塞 非阻塞 / 异步 线程模式 每个连接一个线程 单线程管理多个连接 数据处理单位 字节流 / 字符流 缓冲区 (Buffer) 核心组件 Socket, ServerSoc…...

如何实现高性能超低延迟的RTSP或RTMP播放器

随着直播行业的快速发展&#xff0c;RTSP和RTMP协议成为了广泛使用的流媒体传输协议&#xff0c;尤其是在实时视频直播领域&#xff0c;如何构建一个高性能超低延迟的直播播放器&#xff0c;已经成为了决定直播平台成功与否的关键因素之一。作为音视频直播SDK技术老兵&#xff…...

每天掌握一个Linux命令 - sar

Linux 系统监控工具 sar 使用指南 一、工具概述 sar&#xff08;System Activity Reporter&#xff09; 是 Linux 下功能强大的系统活动报告工具&#xff0c;属于 sysstat 软件包的核心组件。它通过采集系统资源&#xff08;CPU、内存、磁盘、网络、进程等&#xff09;的使用…...

RabbitMQ 集群与高可用方案设计(三)

五、高可用方案设计与实现 &#xff08;一&#xff09;负载均衡与代理 1. HAProxy 配置 HAProxy 是一款广泛应用的开源负载均衡器和代理服务器&#xff0c;它能够实现对 RabbitMQ 集群节点的负载均衡和健康检查&#xff0c;有效提高系统的可用性和性能。以下是使用 HAProxy …...

Linux的读写屏障

在 Linux 中&#xff0c;读写屏障&#xff08;Read-Write Barriers&#xff0c;简称 RWB&#xff09;是对内存访问顺序的一种控制机制&#xff0c;用来保证在多核处理器环境下&#xff0c;内存访问的正确顺序&#xff0c;避免因乱序执行导致的数据一致性问题。它是操作系统内核…...

Vue中的 VueComponent

VueComponent 组件的本质 Vue 组件是一个可复用的 Vue 实例。每个组件本质上就是通过 Vue.extend() 创建的构造函数&#xff0c;或者在 Vue 3 中是由函数式 API&#xff08;Composition API&#xff09;创建的。 // Vue 2 const MyComponent Vue.extend({template: <div…...

C语言数据结构-单向链表

头文件&#xff1a;link.h #ifndef __LINK_H__ #define __LINK_H__ #include <stdio.h> #include <stdlib.h> typedef int DataType; /*节点数据类型*/ typedef struct node { DataType data; //数据域 struct node *pNext; //指…...

小样本分类新突破:QPT技术详解

问题导向式提示调优(QPT) 这篇论文主要讲了一个针对小样本(数据量少)文本分类问题的新方法,叫问题导向式提示调优(QPT)。 核心思路是让预训练语言模型(比如BERT的升级版RoBERTa)在少量标注数据下,通过设计特定的“提问式模板”和“标签词扩展技术”来提升分类效果。…...

Excel常用公式全解析(1):从基础计算到高级应用

Excel常用公式全解析&#xff1a;从基础计算到高级应用 目录 Excel常用公式全解析&#xff1a;从基础计算到高级应用[toc](目录)一、基础计算类&#xff1a;数据运算的基石1. 求和公式&#xff08;SUM&#xff09;2. 平均值公式&#xff08;AVERAGE&#xff09;3. 最值与计数公…...

C++ STL 容器:List 深度解析与实践指南

一、List 容器概述 1.1底层结构与特性 数据结构&#xff1a;双向循环链表&#xff08;带哨兵位头结点&#xff09;&#xff0c;每个节点包含前驱指针、后继指针和数据域。核心优势&#xff1a; 高效插入 / 删除&#xff1a;任意位置操作时间复杂度为 O (1)&#xff0c;无需移…...

每天掌握一个Linux命令 - ab(Apache Benchmark)

Linux 命令工具 ab 使用指南 一、工具概述 ab&#xff08;Apache Benchmark&#xff09; 是 Apache 官方提供的开源压力测试工具&#xff0c;用于衡量 Web 服务器的性能。它通过模拟多并发请求&#xff0c;测试服务器在高负载下的响应速度、吞吐量和稳定性&#xff0c;常用于…...

与 PyCharm 官方沟通解决开发环境问题记录(进展:官方已推出2个新的修复版本)

​​​​​​主题&#xff1a;有关 PyCharm 中终端和环境激活问题的反馈&#xff1a;PY-81233 前言 目前进展&#xff1a; 官方已有2个修复版本推出测试。 更新方法&#xff1a; 使用JetBrains Toolbox App&#xff0c;如下图所示&#xff0c;从“其他版本”进入查看更新。…...

Python的分布式网络爬虫系统实现

1. 系统架构概述 一个典型的分布式网络爬虫系统通常包含以下几个核心组件&#xff1a; 1.主节点&#xff08;Master Node&#xff09;&#xff1a; 任务调度&#xff1a;负责将抓取任务分配给各个工作节点。URL 管理&#xff1a;维护待抓取的 URL 队列和已抓取的 URL 集合&a…...

Vue快速上手(业务、技术、报错)

Vue 技术业务报错 技术 业务 Vueelement-ui&#xff0c;实现表格渲染缩略图&#xff0c;鼠标悬浮缩略图放大&#xff0c;点击缩略图播放视频&#xff08;一&#xff09; 报错 vue修改配置文件.env.development不生效 vue前端downloadFile报错&#xff1a;Error parsing HT…...

taro + vue3 实现小程序sse长连接实时对话

前言 taro.request是可以实现sse长连接的&#xff0c;但是呢其中有俩大坑&#xff0c;找了许多资料也没解决&#xff0c;后续解决办法也与后端商量改用WebSocket来实现。 代码实现 SSEManager.js: import { getAccessToken } from "../xx/xx"; import { TextDecode…...

使用MATLAB求解微分方程:从基础到实践

使用MATLAB求解微分方程&#xff1a;从基础到实践 微分方程是描述自然界和工程领域中许多现象的重要数学工具。MATLAB提供了强大的工具来求解各种类型的微分方程。本文将介绍如何使用MATLAB求解常微分方程(ODE)。 1. 基本ODE求解器 MATLAB提供了多种ODE求解器&#xff0c;最…...

基于MATLAB的大规模MIMO信道仿真

1. 系统模型与参数设置 以下是一个单小区大规模MIMO系统的参数配置示例&#xff0c;适用于多发多收和单发单收场景。 % 参数配置 params.N_cell 1; % 小区数量&#xff08;单小区仿真&#xff09; params.cell_radius 500; % 小区半径&#xff08;米&#xff09…...

如何在 Windows 和 Mac 上擦拭和清洁希捷外置硬盘

希捷外置硬盘广泛用于存储目的&#xff0c;但有时您可能出于多种目的需要擦除或清洁希捷外置硬盘&#xff0c;例如转售、重复使用、捐赠等。为了释放硬盘上的存储空间或确保没有人可以从硬盘中恢复您的信息&#xff0c;擦除硬盘是必要的步骤。无论您使用的是 Windows 还是 Mac&…...

Vue 3.0 中状态管理Vuex 与 Pinia 的区别

在 Vue.js 应用开发中&#xff0c;状态管理是构建复杂应用的关键环节。随着 Vue 3 的普及和 Composition API 的引入&#xff0c;开发者面临着状态管理库的选择问题&#xff1a;是继续使用经典的 Vuex&#xff0c;还是转向新兴的 Pinia&#xff1f;本文将从设计理念、API 设计、…...

第三届黄河流域网安技能挑战赛复现

Web 奶龙牌图片处理器2.0 这题&#xff0c;之前只了解过 .user.ini 文件&#xff0c;并为遇到实操题 但赛前差点就做到下面这题了&#xff0c;不多说&#xff0c;复现之前先看看下面这题 靶场&#xff1a; 攻防世界 没错&#xff0c;又做上文件上传题了&#xff0c;别看…...

python 生成复杂表格,自动分页等功能

py&#xff54;&#xff48;&#xff4f;&#xff4e; 生成复杂表格&#xff0c;自动分页等功能 解决将Python中的树形目录数据转换为Word表格&#xff0c;并生成带有合并单元格的检测报告的问题。首先&#xff0c;要解决“tree目录数据”和“Word表格互换”&#xff0c;指将树…...

2025年高防IP与游戏盾深度对比:如何选择最佳防护方案?

2025年&#xff0c;随着DDoS攻击规模的指数级增长和混合攻击的常态化&#xff0c;高防IP与游戏盾成为企业网络安全的核心选择。然而&#xff0c;两者在功能定位、技术实现及适用场景上存在显著差异。本文结合最新行业实践与技术趋势&#xff0c;全面解析两者的优劣&#xff0c;…...