SQLite命令行程序(CLP)使用指南 📚 2024-12-26 作者 C3P00 在现代数据库管理中,SQLite因其轻量级和高效性而被广泛应用于各种场景。本文将深入探讨SQLite命令行程序(CLP)的多种用法,从基本的操作到高级的数据备份与恢复技巧,帮助读者更好地掌握这一强大的工具。让我们一起开始这段探索之旅吧!🚀 一、通过命令行模式调用CLP 💻 (一)直接执行SQL命令或SQLite shell命令 SQLite提供了两种主要方式来在命令行模式下调用CLP。第一种是提供一个SQL命令或者SQLite shell命令,例如.dump和.schema。任何有效的SQL或SQLite shell命令都可以执行。SQLite会执行指定的命令,将结果打印到标准输出,并退出。例如,要从命令行导出test.db数据库,可以输入以下命令: bash sqlite3 test.db .dump 为了使这个操作更有意义,我们通常需要将输出重定向到一个文件中: bash sqlite3 test.db .dump > test.sql 这样,test.sql文件就包含了test.db数据库完整的、可读的人类可理解的DDL(数据定义语言)和DML(数据操作语言)语句。 如果想要选择test表中的所有记录,可以这样做: bash sqlite3 test.db "select * from test" (二)将文件作为输入流进行重定向 第二种方式是将一个文件作为输入流重定向给CLP。比如,要从我们的数据库转储文件test.sql创建一个新的数据库test2.db,可以按照以下步骤操作: bash sqlite3 test2.db < test.sql CLP会将文件作为标准输入读取,然后处理并应用其中的所有SQL命令到test2.db数据库文件上。 另一种从test.sql文件创建数据库的方法是使用init选项并将test.sql作为参数传递: bash sqlite3 –init test.sql test3.db 这种情况下,CLP会处理test.sql,创建test3.db数据库,然后进入shell模式。为什么呢?因为这次调用没有包含SQL命令或输入流。为了解决这个问题,你需要提供一个SQL命令或SQLite shell命令,例如: bash sqlite3 –init test.sql test3.db .exit .exit命令提示CLP以命令行模式运行,并尽可能少地做事情。总的来说,重定向可能是从命令行处理文件最简单的方法。😉 二、数据库备份的重要性 🗳️ 数据库备份是确保数据安全的关键环节,它可以在发生意外时快速恢复数据。根据所需的备份类型,有几种不同的方法可供选择。 (一)SQL转储是最便携的备份形式 SQL转储可能是保持备份最便携的形式。生成SQL转储的标准方法是使用CLP的.dump命令,如前文所述。从命令行执行如下操作: bash sqlite3 test.db .dump > test.sql 在shell内部,你可以将输出重定向到外部文件,发出命令,然后将输出恢复到屏幕上: sql sqlite> .output file.sql sqlite> .dump sqlite> .output stdout sqlite> .exit 同样地,导入数据库最简单的方法是将SQL转储作为输入流提供给CLP: bash sqlite3 test.db < test.sql 这假设test.db不存在。如果它已经存在,只要test.sql的内容与test.db不同,那么事情仍然可能正常工作。当然,如果test.sql包含已经在test.db中存在的对象或者包含违反主键或外键约束的数据,你会遇到错误(不过,请参阅后续章节关于PRAGMA讨论如何处理这种情况)。🧐 (二)二进制备份 制作数据库的二进制备份基本上就是一个文件复制的过程。在此之前,你可能希望执行一个小操作——对数据库进行真空操作(vacuum),这将释放由已删除对象创建的未使用空间。这将为你从二进制复制得到的文件提供更小的结果: bash sqlite3 test.db vacuum cp test.db test.backup 一般而言,二进制备份不如SQL备份那样具有良好的可移植性。虽然SQLite在同一数据库格式下具有良好的向后兼容性和跨平台的二进制兼容性,但对于长期备份来说,始终建议使用SQL形式。如果大小是一个问题,SQL格式(原始文本)通常会产生不错的压缩比率。⚠️ 注意:无论你认为自己选择的备份方法有多好,记住你只与最后一次成功的还原一样好。如果你需要依赖它,请测试你的还原过程——否则,即使你进行了多次成功的备份,你也只会因一次失败的还原而被记住。 最后,如果你曾经与其他数据库打过交道,“删除”SQLite中的数据库就像二进制备份一样简单,只需删除你想删除的数据库文件即可。
在现代数据库管理中,SQLite因其轻量级和高效性而被广泛应用于各种场景。本文将深入探讨SQLite命令行程序(CLP)的多种用法,从基本的操作到高级的数据备份与恢复技巧,帮助读者更好地掌握这一强大的工具。让我们一起开始这段探索之旅吧!🚀
一、通过命令行模式调用CLP 💻
(一)直接执行SQL命令或SQLite shell命令
SQLite提供了两种主要方式来在命令行模式下调用CLP。第一种是提供一个SQL命令或者SQLite shell命令,例如
.dump
和.schema
。任何有效的SQL或SQLite shell命令都可以执行。SQLite会执行指定的命令,将结果打印到标准输出,并退出。例如,要从命令行导出test.db
数据库,可以输入以下命令:bash
sqlite3 test.db .dump
为了使这个操作更有意义,我们通常需要将输出重定向到一个文件中:
bash
sqlite3 test.db .dump > test.sql
这样,
test.sql
文件就包含了test.db
数据库完整的、可读的人类可理解的DDL(数据定义语言)和DML(数据操作语言)语句。如果想要选择
test
表中的所有记录,可以这样做:bash
sqlite3 test.db "select * from test"
(二)将文件作为输入流进行重定向
第二种方式是将一个文件作为输入流重定向给CLP。比如,要从我们的数据库转储文件
test.sql
创建一个新的数据库test2.db
,可以按照以下步骤操作:bash
sqlite3 test2.db < test.sql
CLP会将文件作为标准输入读取,然后处理并应用其中的所有SQL命令到
test2.db
数据库文件上。另一种从
test.sql
文件创建数据库的方法是使用init
选项并将test.sql
作为参数传递:bash
sqlite3 –init test.sql test3.db
这种情况下,CLP会处理
test.sql
,创建test3.db
数据库,然后进入shell模式。为什么呢?因为这次调用没有包含SQL命令或输入流。为了解决这个问题,你需要提供一个SQL命令或SQLite shell命令,例如:bash
sqlite3 –init test.sql test3.db .exit
.exit
命令提示CLP以命令行模式运行,并尽可能少地做事情。总的来说,重定向可能是从命令行处理文件最简单的方法。😉二、数据库备份的重要性 🗳️
数据库备份是确保数据安全的关键环节,它可以在发生意外时快速恢复数据。根据所需的备份类型,有几种不同的方法可供选择。
(一)SQL转储是最便携的备份形式
SQL转储可能是保持备份最便携的形式。生成SQL转储的标准方法是使用CLP的
.dump
命令,如前文所述。从命令行执行如下操作:bash
sqlite3 test.db .dump > test.sql
在shell内部,你可以将输出重定向到外部文件,发出命令,然后将输出恢复到屏幕上:
sql
sqlite> .output file.sql
sqlite> .dump
sqlite> .output stdout
sqlite> .exit
同样地,导入数据库最简单的方法是将SQL转储作为输入流提供给CLP:
bash
sqlite3 test.db < test.sql
这假设
test.db
不存在。如果它已经存在,只要test.sql
的内容与test.db
不同,那么事情仍然可能正常工作。当然,如果test.sql
包含已经在test.db
中存在的对象或者包含违反主键或外键约束的数据,你会遇到错误(不过,请参阅后续章节关于PRAGMA讨论如何处理这种情况)。🧐(二)二进制备份
制作数据库的二进制备份基本上就是一个文件复制的过程。在此之前,你可能希望执行一个小操作——对数据库进行真空操作(vacuum),这将释放由已删除对象创建的未使用空间。这将为你从二进制复制得到的文件提供更小的结果:
bash
sqlite3 test.db vacuum
cp test.db test.backup
一般而言,二进制备份不如SQL备份那样具有良好的可移植性。虽然SQLite在同一数据库格式下具有良好的向后兼容性和跨平台的二进制兼容性,但对于长期备份来说,始终建议使用SQL形式。如果大小是一个问题,SQL格式(原始文本)通常会产生不错的压缩比率。⚠️ 注意:无论你认为自己选择的备份方法有多好,记住你只与最后一次成功的还原一样好。如果你需要依赖它,请测试你的还原过程——否则,即使你进行了多次成功的备份,你也只会因一次失败的还原而被记住。
最后,如果你曾经与其他数据库打过交道,“删除”SQLite中的数据库就像二进制备份一样简单,只需删除你想删除的数据库文件即可。