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

news2024/12/26 21:30:24

之前在做围绕数据库相关的一些小工具的时候,想找一款数据库作为小工具的资料库。需求是:不用复杂的安装,支持简单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.coloradmin.cn/o/2144850.html

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

相关文章

递归7小题

[ 注意&#xff1a;前6道题均是使用递归完成的&#xff0c;需要数组、指针、链表相关知识&#xff0c;第7道题是求水仙花数的加强版&#xff0c;也是使用递归完成的&#xff0c;3位数的水仙花数我们很熟悉&#xff0c;那5位数的呢&#xff1f;7位数的呢&#xff1f;9位数的呢&a…

【pycharm】如何两个窗口打开同一代码

文章目录 前言解决方案结果 前言 在 编辑长代码&#xff0c;要看上下离得较远的变量 时遇到的问题 解决方案 “window” → “Editor Tabs” → “Split right" 结果

CleanClip vs 传统剪贴板:究竟谁更胜一筹?

在日常工作和生活中,复制粘贴可以说是我们使用最频繁的操作之一。传统的剪贴板功能虽然简单易用,但在功能性和效率上还有很大的提升空间。今天,我们就来比较一下新兴的剪贴板增强工具CleanClip与传统剪贴板,看看到底谁更胜一筹。 1. 剪贴历史管理 传统剪贴板只能存储最后一次…

动态线程池实战(一)

动态线程池 对项目的认知 为什么需要动态线程池 DynamicTp简介 接入步骤 功能介绍 模块划分 代码结构介绍

设计模式学习[6]---代理模式

文章目录 前言1.原理阐述2.举例2.1 例子与类图2.2 代码 总结 前言 代理这个词&#xff0c;从小到大听过不少。比如什么代理服务器&#xff0c;代理商&#xff0c;代理人之类的。通俗来说&#xff0c;代理无非无非就是我代表你处理事务的意思。 那么在设计模式中&#xff0c;针…

Android WebView H5 Hybrid 混和开发

对于故乡&#xff0c;我忽然有了新的理解&#xff1a;人的故乡&#xff0c;并不止于一块特定的土地&#xff0c;而是一种辽阔无比的心情&#xff0c;不受空间和时间的限制&#xff1b;这心情一经唤起&#xff0c;就是你已经回到了故乡。——《记忆与印象》 前言 移动互联网发展…

智能车镜头组入门(三)巡线

镜头组的特点是通过摄像头来获取赛道的信息&#xff0c;从而达到前瞻的效果&#xff0c;完成转向和速度决策。 我们的方案&#xff0c;带上元素识别&#xff0c;大概在TC264上5ms一帧&#xff0c;所以我们开了100hz的图象。 之前我看别的博客上有人说&#xff0c;他们组的50帧…

MyBatis框架SqlSession浅析

1、SqlSessionFactory作用 MyBatis框架SqlSessionFactory是线程安全的&#xff0c;负责创建SqlSession。 DefaultSqlSessionFactory是线程安全的&#xff0c;属性Final。 2、SqlSessionFactoryBuilder SqlSessionFactoryBuilder负责创建SqlSessionFactory。SqlSessionFactory…

C++伟大发明--模版

C起初是不受外界关注的&#xff0c;别人觉得他和C语言没有本质上的区别&#xff0c;只是方便些&#xff0c;直到祖师爷发明了模版&#xff0c;开始和C语言有了根本的区别。 我们通过一个小小的例子来搞清楚什么是模版&#xff0c;模版的作用到底有多大&#xff0c;平时我们想要…

UAC2.0 麦克风——类特殊请求

UAC2.0 麦克风枚举过程参考 UAC2.0 麦克风——单声道 USB 麦克风(16bit) 文章目录 set interfaceget device status类特殊请求get curget rangevolume rangesample rangeset interface USB 请求代码 typedef enum {USB_REQ_GET_STATUS = 0 ,USB_REQ_CLEAR_FEATURE …

自动化中验证码的操作笔记,懂的赶紧收藏!

在自动化测试的过程中&#xff0c;验证码一直被视为一个“拦路虎”。很多测试人员在做接口或UI自动化时都会遇到验证码的阻碍&#xff0c;导致测试无法继续进行。今天&#xff0c;我们就来讨论如何在自动化过程中破解验证码&#xff0c;快速绕过这道关卡&#xff0c;轻松完成自…

【C51】独立按键控制LED灯

1.简介 在单片机应用系统中&#xff0c;常常使用轻触按键组成键盘。轻触按键具有自动回弹的特点&#xff0c;即按下按键&#xff0c;两个触点接通&#xff0c;放开按键&#xff0c;两个触点断开。轻触按键的外形及电路符号如图&#xff0c;通常轻触按键有4个引脚&#xff0c;4个…

Redis - 深入理解Redis事务

目录 Redis是如何实现事务的&#xff1f;事务中执行的命令出现错误&#xff0c;会回滚事务吗&#xff1f;同一个连接可以重复开启事务吗&#xff1f;多个客户端同时开启事务会怎样&#xff1f;使用Redis事务只用MULTI和EXEC吗&#xff1f;Redis中的WATCH机制是怎么实现的&#…

GAMES104:13 引擎工具链基础-学习笔记

文章目录 一&#xff0c;工具链二&#xff0c;复杂的工具2.1 界面GUI2.2 设计模式Design Pattern2.3 数据的加载和存储2.4 资产引用 三&#xff0c;资产加载Deserialization3.1 资产解析Parse3.2 资产版本兼容性&#xff08;Compatibility&#xff09; 四&#xff0c; 如何制作…

搞安全必看——IPS和IDS到底有啥区别?

号主&#xff1a;老杨丨11年资深网络工程师&#xff0c;更多网工提升干货&#xff0c;请关注公众号&#xff1a;网络工程师俱乐部 下午好&#xff0c;我的网工朋友。 随着数字化转型的加速推进&#xff0c;网络安全已成为各行业不可或缺的一环。对于现代企业和组织而言&#x…

【JavaEE初阶】多线程6(线程池\定时器)

欢迎关注个人主页&#xff1a;逸狼 创造不易&#xff0c;可以点点赞吗~ 如有错误&#xff0c;欢迎指出~ 目录 实例3:线程池 参数解释 核心线程数, 最大线程数 允许空闲的最大时间 ,时间单位 任务队列(阻塞队列) 线程工厂>工厂设计模式 拒绝策略 使用举例 模拟实现一个线…

从零开始讲DDR(0)——DDR的前世今生

一、计算机组成 计算机组成结构&#xff08;Computer Architecture&#xff09;是计算机系统的核心&#xff0c;它定义了计算机的基本工作原理和设计模式。计算机的组成可以分成以下3大类&#xff1a;中央处理器&#xff08;CPU&#xff09;、存储器和输入/输出子系统。 1.1 中…

Linux文件IO-基础知识了解及文件描述符

1、简介 本章给大家介绍 Linux 应用编程中最基础的知识&#xff0c;即文件 I/O&#xff08;Input、Outout&#xff09;&#xff0c;文件 I/O 指的是对文件的输入/输出操作&#xff0c;说白了就是对文件的读写操作&#xff1b;Linux 下一切皆文件&#xff0c;文件作为 Linux 系…

深度学习 之 常见损失函数简介:名称、作用及用法

引言 在机器学习和深度学习中&#xff0c;损失函数&#xff08;Loss Function&#xff09;是模型训练过程中一个不可或缺的部分。它用来度量模型预测结果与真实值之间的差异&#xff0c;从而指导模型参数的优化。合理选择损失函数对于提高模型的准确性和泛化能力至关重要。本文…

Mint Expedition Season 3 拉开帷幕:登顶高峰的时刻到了

自 7 月 15 日 Mint Expedition 启动以来&#xff0c;Mint&#xff0c;一条专注于 NFT 行业的以太坊 Layer 2&#xff0c;日常交易量和交易额都出现了爆发式增长。这一成功离不开 Mint 社区的合作&#xff0c;包括 Minters、Web3 去中心化应用程序的开发者&#xff0c;以及大量…