【SQLite数据库常规使用命令】

之前在做围绕数据库相关的一些小工具的时候,想找一款数据库作为小工具的资料库。需求是:不用复杂的安装,支持简单SQL,空间占用小,操作简单等等。
结合着之前接触到的一些研发同事做的产品的使用经验,我想到了这款轻量级的数据库----SQLite。

SQLite遵守‌ACID,它的设计目标是嵌入式的,已经被广泛用于各种嵌入式设备和应用程序中。大多数的操作系统已经预装了SQLite,如果没有,用包管理器装一下sqlite3就可以了。

如下是一部分使用SQLite的常规命令,供参考

一、登陆/创建数据库

直接执行 sqlite3 filename 打开或创建一个 SQLite 数据库。如果文件不存在,SQLite 会自动创建它。

sqlite3 db1.db

也可以首先创建一个空白文件,然后使用 sqlite3 命令打开它。

touch db02.db
sqlite3 db02.db

二、查看当前访问的数据库以及切换数据库

.database

image.png

.open database_name

image.png

三、查看帮助命令

直接.help查看所有可用的命令

.help

image.png

.help跟命令,可以只查看和这个操作的解释

.help .table

image.png

四、SQLite 增删改查

sqlite> create table t1(name text,age int);
sqlite> insert into t1 values('xmaster',20);
sqlite> insert into t1 values('xmaster2',10);
sqlite> select * from t1;
xmaster|20
xmaster2|10
//建索引
sqlite> create index user_name on t1(name);

五、显示格式

觉得上边查询的结果显示的不好看,可以用.mode改变输出格式。可用的输出格式为:ascii、box、csv、column、html、insert、json、line、list、markdown、quote、table。

sqlite> .mode insert
sqlite> select * from t1;
INSERT INTO "table"(name,age) VALUES('xmaster',20);
INSERT INTO "table"(name,age) VALUES('xmaster2',10);
sqlite> .mode table
sqlite> select * from t1;
+----------+-----+
|   name   | age |
+----------+-----+
| xmaster  | 20  |
| xmaster2 | 10  |
+----------+-----+
sqlite> .mode html
sqlite> select * from t1;
<TR><TD>xmaster</TD>
<TD>20</TD>
</TR>
<TR><TD>xmaster2</TD>
<TD>10</TD>
</TR>
sqlite> .mode json
sqlite> select * from t1;
[{"name":"xmaster","age":20},
{"name":"xmaster2","age":10}]
sqlite> .mode column
sqlite> select * from t1;
name      age
--------  ---
xmaster   20
xmaster2  10
sqlite> .mode box
sqlite> select * from t1;
┌──────────┬─────┐
│   name   │ age │
├──────────┼─────┤
│ xmaster  │ 20  │
│ xmaster2 │ 10  │
└──────────┴─────┘
sqlite>
sqlite> .mode quote
sqlite> select * from t1;
'name','age'
'xmaster',20
'xmaster2',10

六、查看对象

比较类似于PostgreSQL的元命令

.schema 查看 schema 详情

sqlite> .schema
CREATE TABLE t1(name text,age int);
CREATE INDEX user_name on t1(name);
CREATE TABLE t2(id int);

查看表

sqlite> .table
t1

对应的具体SQL为

SELECT name FROM sqlite_schema WHERE type IN ('table','view') AND name NOT LIKE 'sqlite_%';

查看索引

sqlite> .index
user_name

对应的具体SQL为

SELECT name FROM sqlite_schema WHERE type IN ('index') AND name NOT LIKE 'sqlite_%';

支持模糊查询(模糊查询是用%)

sqlite> create table t2(id int);
sqlite> .table t%
t1  t2
sqlite> .table %2
t2

也可以.table 跟表名,看是否有这张表

sqlite> .table t1
t1
sqlite> .table t3
sqlite>

七、sqlite_master/sqlite_schema表

sqlite_master 是 SQLite 中的一个特殊表,其中包含了数据库的 schema 信息。你可以查询这个表以获取表的创建语句和索引信息。

sqlite> select * from sqlite_schema;
+-------+-----------+----------+----------+------------------------------------+
| type  |   name    | tbl_name | rootpage |                sql                 |
+-------+-----------+----------+----------+------------------------------------+
| table | t1        | t1       | 2        | CREATE TABLE t1(name text,age int) |
| index | user_name | t1       | 3        | CREATE INDEX user_name on t1(name) |
| table | t2        | t2       | 4        | CREATE TABLE t2(id int)            |
+-------+-----------+----------+----------+------------------------------------+
sqlite> select * from sqlite_master;
+-------+-----------+----------+----------+------------------------------------+
| type  |   name    | tbl_name | rootpage |                sql                 |
+-------+-----------+----------+----------+------------------------------------+
| table | t1        | t1       | 2        | CREATE TABLE t1(name text,age int) |
| index | user_name | t1       | 3        | CREATE INDEX user_name on t1(name) |
| table | t2        | t2       | 4        | CREATE TABLE t2(id int)            |
+-------+-----------+----------+----------+------------------------------------+

八、结果输出到文件(.output filename)

使用 .output filename 命令将查询结果写入指定文件。(类似于PostgreSQL的\o)
.exit是退出数据库,类似于PostgreSQL的\q

sqlite> .output ysla.log
sqlite> select * from t1;
sqlite> .exit
root@ubuntu-linux-22-04-desktop:~# cat ysla.log
+----------+-----+
|   name   | age |
+----------+-----+
| xmaster  | 20  |
| xmaster2 | 10  |
+----------+-----+

九、读取运行 SQL 脚本(.read filename.sql)

root@ubuntu-linux-22-04-desktop:~# cat a.sql
select * from t1;
root@ubuntu-linux-22-04-desktop:~# sqlite3 db02.db
SQLite version 3.37.2 2022-01-06 13:25:41
Enter ".help" for usage hints.
sqlite> .mode table
sqlite> .read a.sql
+----------+-----+
|   name   | age |
+----------+-----+
| xmaster  | 20  |
| xmaster2 | 10  |
+----------+-----+

十、SQLite 备份与恢复

(1)备份

使用.output backup.sql结合.dump

sqlite> .database
main: /root/db02.db r/w
sqlite> .output backup.sql
sqlite> .dump
sqlite> .exit
root@ubuntu-linux-22-04-desktop:~# cat backup.sql
PRAGMA foreign_keys=OFF;
BEGIN TRANSACTION;
CREATE TABLE t1(name text,age int);
INSERT INTO t1 VALUES('xmaster',20);
INSERT INTO t1 VALUES('xmaster2',10);
CREATE TABLE t2(id int);
CREATE INDEX user_name on t1(name);
COMMIT;

(2)恢复

主要利用read命令应用

root@ubuntu-linux-22-04-desktop:~# sqlite3 db3.db
SQLite version 3.37.2 2022-01-06 13:25:41
Enter ".help" for usage hints.
sqlite> .read  backup.sql
sqlite> .table
t1  t2
sqlite> select * from t1;
xmaster|20
xmaster2|10

(3)备份单个对象

sqlite> .output backup.sql
sqlite> .dump object_name
sqlite> .exit

(4)获取对象的结构/创建语句

sqlite> select * from t1;
xmaster|20
xmaster2|10
sqlite> .dump t1
PRAGMA foreign_keys=OFF;
BEGIN TRANSACTION;
CREATE TABLE t1(name text,age int);
INSERT INTO t1 VALUES('xmaster',20);
INSERT INTO t1 VALUES('xmaster2',10);
COMMIT;
sqlite> .index
user_name
sqlite> .dump user_name
PRAGMA foreign_keys=OFF;
BEGIN TRANSACTION;
CREATE INDEX user_name on t1(name);
COMMIT;

十一、SQL 函数

支持的SQL函数可以参考这个链接 https://www.sqlite.org/lang_corefunc.html

十二、如何不sqlite进入数据库,在外边执行sql

以 sqlite3 dbname sql的格式执行即可

root@ubuntu-linux-22-04-desktop:~# sqlite3 db02.db "select * from t1;"
xmaster|20
xmaster2|10

可以跟上显示的格式

root@ubuntu-linux-22-04-desktop:~# sqlite3 db02.db "select * from t1;" -table
+----------+-----+
|   name   | age |
+----------+-----+
| xmaster  | 20  |
| xmaster2 | 10  |
+----------+-----+
root@ubuntu-linux-22-04-desktop:~# sqlite3 db02.db "select * from t1;" -json
[{"name":"xmaster","age":20},
{"name":"xmaster2","age":10}]
root@ubuntu-linux-22-04-desktop:~# sqlite3 db02.db "select * from t1;" -box
┌──────────┬─────┐
│   name   │ age │
├──────────┼─────┤
│ xmaster  │ 20  │
│ xmaster2 │ 10  │
└──────────┴─────┘

十三、如何不sqlite进入数据库,在外边执行sql脚本

root@ubuntu-linux-22-04-desktop:~# sqlite3 db02.db ".read a.sql" -table
+----------+-----+
|   name   | age |
+----------+-----+
| xmaster  | 20  |
| xmaster2 | 10  |
+----------+-----+

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

华为HarmonyOS地图服务 3 - 如何开启和展示“我的位置”?

一. 场景介绍 本章节将向您介绍如何开启和展示“我的位置”功能&#xff0c;“我的位置”指的是进入地图后点击“我的位置”显示当前位置点的功能。效果如下&#xff1a; 二. 接口说明 “我的位置”功能主要由MapComponentController的方法实现&#xff0c;更多接口及使用方法…

基于LSTM的温度时序预测

1.背景 本文接【时序预测SARIMAX模型】 一文&#xff0c;采用LSTM模型进行平均温度数据预测。具体的背景和数据分析就不做重复说明&#xff0c;感兴趣可以去看上文即可。 2.LSTM模型 RNN&#xff08;Recurrent Neural Network&#xff0c;循环神经网络&#xff09;是一种特殊…

【ARM】armv8的虚拟化深度解读

Type-1 hypervisor Type-1虚拟化也叫做Bare metal, standalone, Type1 Type2 hypervisor Type-2虚拟化也叫做hosted, Type-2 VM和vCPU(虚拟机和虚拟cpu) 在一个VM&#xff08;虚拟机&#xff09;中有多个vCPU&#xff0c;多个vCPU可能属于同一个Vritual Processor。 EL2…

java-----异常

目录 异常&#xff1a;代表程序出现的问题 运行时异常和编译时异常的区别&#xff1f; 异常的作用&#xff1a; 异常的处理方式: 异常中常见的方法: 抛出异常: 自定义异常: 异常&#xff1a;代表程序出现的问题 Exception:叫做异常&#xff0c;代表程序可能出现的问题。…

【alluxio编译报错】Some files do not have the expected license header

Some files do not have the expected license header 快捷导航 在开始解决问题之前&#xff0c;大家可以通过下面的导航快速找到相关资源啦&#xff01;&#x1f4a1;&#x1f447; 快捷导航链接地址备注相关文档-ambaribigtop自定义组件集成https://blog.csdn.net/TTBIGDA…

【JavaScript】LeetCode:46-50

文章目录 46 翻转二叉树47 对称二叉树48 二叉树的直径49 二叉树的层序遍历50 将有序数组转换为二叉搜索树 46 翻转二叉树 递归前序遍历 / 后序遍历&#xff0c;这里给出前序遍历的代码。遍历节点&#xff0c;交换左右子树。 /*** Definition for a binary tree node.* functio…

vue3快速入门(看心情更新)

vue3初始化工程目录 编写一个App .vscode下的extensions.json 配置插件的地方 public 页签图标 src 你的.vue文件都是在这个目录下的 .gitgnore 忽略文件 env.d.ts 让Ts去识别一些文件 index.html 入口文件 vite.config.ts 整个工程的配置文件 .vue文件中可以写的内容 template…

Windows安装Oracle11gR2(图文教程)

本章教程&#xff0c;记录在Windows10上安装Oracle11gR2过程。 一、下载安装包 通过网盘分享的文件&#xff1a;oracle11g 链接: https://pan.baidu.com/s/15ilciQ5NlKWtClklmdAH_w?pwds4dd 提取码: s4dd 二、下载并解压文件 将网盘中的安装包文件下载到本地&#xff0c;在此之…

心觉:感恩何其重要,感恩之心如何培养

Hi&#xff0c;我是心觉&#xff0c;与你一起玩转潜意识、脑波音乐和吸引力法则&#xff0c;轻松掌控自己的人生&#xff01; 挑战每日一省写作177/1000天 上篇文章我们讲了保持感恩之心&#xff0c;可以吸引更多的机会和财富 但是现实中很多人是缺乏感恩之心 这是由于他们…

c++day3 手动封装一个顺序表(SeqList),分文件编译实现

要求: 有私有成员&#xff1a;顺序表数组的起始地址 ptr、 顺序表的总长度&#xff1a;size、顺序表的实际长度&#xff1a;len 成员函数&#xff1a;初始化 init(int n) 判空&#xff1a;empty 判满&#xff1a;full 尾插&#xff1a;push_back 插入&#xff1a;insert&…

进程间的通信4 共享内存

共享内存 1.共享内存简介 共享内存是将分配的物理空间直接映射到进程的用户虚拟地址空间中&#xff0c;减少数据在内核空间缓存共享内存是一种效率较高的进程间通讯的方式在 Linux 系统中通过 ipcs -m 查看所有的共享内存 共享内存模型图 2.共享内存的创建 1.函数头文件 #…

【如何在 Windows 10 主机上通过 VMware 安装 Windows 11 虚拟机,并共享主机网络】

环境说明 主机操作系统&#xff1a;Windows 10虚拟机操作系统&#xff1a;Windows 11虚拟机软件&#xff1a;VMware 步骤一&#xff1a;确保主机&#xff08;Windows 10&#xff09;网络连接正常 启动网络加速软件&#xff1a;在主机上启动软件&#xff0c;确保主机可以正常访…

JavaEE: 深入探索TCP网络编程的奇妙世界(三)

文章目录 TCP核心机制TCP核心机制三: 连接管理建立连接(三次握手)断开连接(四次挥手)三次握手/四次挥手 流程简图 TCP核心机制 书接上文~ TCP核心机制三: 连接管理 建立连接(三次握手),断开连接(四次挥手). 这里的次数指的是网络通信的次数,挥手/握手是形象的比喻(handshake…

基于SpringBoot+Vue的智慧物业管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 精品专栏&#xff1a;Java精选实战项目源码、Python精…

SpringBoot3核心特性-核心原理

目录 传送门前言一、事件和监听器1、生命周期监听2、事件触发时机 二、自动配置原理1、入门理解1.1、自动配置流程1.2、SPI机制1.3、功能开关 2、进阶理解2.1、 SpringBootApplication2.2、 完整启动加载流程 三、自定义starter1、业务代码2、基本抽取3、使用EnableXxx机制4、完…

SaaS软件的配置化平台是如何实现个性化定制的?

SaaS&#xff08;Software as a Service&#xff0c;软件即服务&#xff09;是一种通过互联网提供软件的模式&#xff0c;用户无需安装和维护任何复杂的基础设施&#xff0c;只需通过网络连接即可使用软件。SaaS 供应商负责软件的维护、升级和可用性&#xff0c;用户则通过订阅…

智能体时代,AI正从“神坛”走向“人间”

从通用大模型到行业大模型&#xff1a;AI智能体引领新风口 在人工智能领域&#xff0c;一场深刻的变革正悄然发生。从昔日高高在上的通用大模型&#xff0c;到如今愈发接地气的行业大模型&#xff0c;AI的风向标已经鲜明地指向了AI智能体&#xff08;AI Agent&#xff09;&…

APO v0.4.0 发布:新增影响面分析;新增调用数据库指标;优化告警事件关联展示

APO 新版本 v0.4.0 正式发布&#xff01;本次更新主要包含以下内容&#xff1a; 新增影响面分析&#xff0c;识别服务端点对服务入口的影响 服务入口是指业务被访问时调用的第一个服务端点&#xff0c;在调用拓扑图中处于最上游。服务入口直接反映了系统对外提供服务的状态&a…

基于SpringBoot+Vue+MySQL的手机销售管理系统

系统展示 用户前台界面 管理员后台界面 商家后台界面 系统背景 随着智能手机的普及和市场竞争的日益激烈&#xff0c;手机销售行业面临着前所未有的挑战与机遇。传统的手工记录和简单的电子表格管理方式已难以满足现代手机销售业务的需求&#xff0c;销售数据的混乱和管理效率低…

(done) 声音信号处理基础知识(2) (重点知识:pitch)(Sound Waveforms)

来源&#xff1a;https://www.youtube.com/watch?vbnHHVo3j124 复习物理知识&#xff1a; 声音由物体的振动产生 物体振动会导致空气分支振荡 某一处的空气气压变化会创造一个波 声音是机械波 空气的振荡在空间中传递 能量从空间中的一个点到另一个点 机械波需要媒介&#x…