如何使用 SQLite ?

SQLite 是一个轻量级、嵌入式的关系型数据库管理系统(RDBMS)。它是一种 C 库,实现了自给自足、无服务器、零配置、事务性 SQL 数据库引擎。SQLite 的源代码是开放的,完全在公共领域。它被广泛用于各种应用程序,包括浏览器、操作系统、移动应用等。

SQLite 的基本特性

  1. 轻量级:SQLite 的库文件非常小,通常只有几百KB。
  2. 自包含:SQLite 不依赖于外部的服务器进程,所有的数据都存储在一个单一的文件中。
  3. 零配置:无需安装和配置,数据库可以直接使用。
  4. 事务性:SQLite 支持原子性、可一致性、隔离性和持久性(ACID)的事务。
  5. 跨平台:SQLite 可以在 Windows、Linux、macOS、iOS 和 Android 等多个平台上运行。
  6. 高效:对于大多数单用户应用和嵌入式系统,SQLite 提供了足够的性能。

SQLite 安装和配置

使用 SQLite 不需要复杂的安装和配置步骤。大多数现代的编程语言和开发环境都内置了 SQLite 支持。以下是一些常见环境中如何安装和使用 SQLite 的方法:

在 Python 中使用 SQLite

Python 标准库中包含了 SQLite 的支持,可以通过 sqlite3 模块直接使用。

import sqlite3# 创建数据库连接
conn = sqlite3.connect('example.db')# 创建游标对象
cursor = conn.cursor()# 创建表
cursor.execute('''CREATE TABLE IF NOT EXISTS users(id INTEGER PRIMARY KEY, name TEXT, age INTEGER)''')# 插入数据
cursor.execute('''INSERT INTO users (name, age) VALUES (?, ?)''', ('Alice', 25))
cursor.execute('''INSERT INTO users (name, age) VALUES (?, ?)''', ('Bob', 30))# 提交事务
conn.commit()# 查询数据
cursor.execute('''SELECT * FROM users''')
rows = cursor.fetchall()
for row in rows:print(row)# 关闭连接
conn.close()
在命令行中使用 SQLite

SQLite 提供了一个命令行工具,可以直接操作 SQLite 数据库。以下是一些常见的命令:

# 启动 SQLite 命令行工具
$ sqlite3 example.db# 创建表
sqlite> CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER);# 插入数据
sqlite> INSERT INTO users (name, age) VALUES ('Alice', 25);
sqlite> INSERT INTO users (name, age) VALUES ('Bob', 30);# 查询数据
sqlite> SELECT * FROM users;
1|Alice|25
2|Bob|30# 退出命令行工具
sqlite> .exit

SQLite 的基本操作

创建数据库和表

在 SQLite 中,创建一个新的数据库实际上是创建一个新的文件。可以通过 sqlite3 工具或程序代码来创建数据库和表。

CREATE TABLE users (id INTEGER PRIMARY KEY,name TEXT NOT NULL,age INTEGER NOT NULL
);
插入数据

可以使用 INSERT INTO 语句向表中插入数据。

INSERT INTO users (name, age) VALUES ('Charlie', 22);
查询数据

可以使用 SELECT 语句从表中查询数据。

SELECT * FROM users;
更新数据

可以使用 UPDATE 语句更新表中的数据。

UPDATE users SET age = 26 WHERE name = 'Alice';
删除数据

可以使用 DELETE 语句删除表中的数据。

DELETE FROM users WHERE name = 'Bob';
使用索引

索引可以加速数据库的查询速度。可以使用 CREATE INDEX 语句创建索引。

CREATE INDEX idx_name ON users (name);

高级功能

事务

事务是一组操作的集合,这些操作要么全部执行,要么全部不执行。SQLite 支持事务,并且默认在每个独立的 INSERTUPDATEDELETE 操作后自动提交事务。可以手动管理事务以提高性能。

BEGIN TRANSACTION;
INSERT INTO users (name, age) VALUES ('Dave', 28);
UPDATE users SET age = 29 WHERE name = 'Charlie';
COMMIT;
视图

视图是基于查询结果的虚拟表。可以使用 CREATE VIEW 语句创建视图。

CREATE VIEW user_names AS
SELECT name FROM users;
触发器

触发器是在某些表操作(如 INSERTUPDATEDELETE)发生时自动执行的一段代码。可以使用 CREATE TRIGGER 语句创建触发器。

CREATE TRIGGER user_age_check
BEFORE INSERT ON users
FOR EACH ROW
WHEN NEW.age < 0
BEGINSELECT RAISE(FAIL, 'Age cannot be negative');
END;
外键约束

SQLite 支持外键约束,从而确保数据的完整性。可以在创建表时定义外键约束。

CREATE TABLE orders (id INTEGER PRIMARY KEY,user_id INTEGER,product TEXT,FOREIGN KEY (user_id) REFERENCES users (id)
);

性能优化

使用事务

将多个操作放在一个事务中可以显著提高性能。默认情况下,每个 INSERTUPDATEDELETE 操作后 SQLite 都会自动提交事务,这会导致大量的磁盘写入操作。可以通过手动管理事务来减少这种开销。

conn = sqlite3.connect('example.db')
cursor = conn.cursor()# 开始事务
conn.execute('BEGIN TRANSACTION')for i in range(1000):cursor.execute('INSERT INTO users (name, age) VALUES (?, ?)', ('User'+str(i), 20+i))# 提交事务
conn.commit()
conn.close()
使用适当的数据类型

尽量使用合适的数据类型来存储数据,可以减少存储空间并提高查询性能。例如,使用 INTEGER 来存储数字,而不是使用 TEXT

创建索引

为常用的查询字段创建索引,可以显著提高查询速度。但是,索引也会增加插入和更新操作的开销,因此应根据实际情况平衡利弊。

SQLite 的常见应用场景

嵌入式系统

由于其轻量级和自包含的特性,SQLite 非常适合嵌入式系统和设备。例如,在智能手机、电视和车载系统中,SQLite 经常被用作本地数据存储解决方案。

单用户应用程序

对于单用户应用程序,如桌面软件或移动应用,SQLite 是一个理想的选择。它不需要服务器进程,部署简单,并且提供足够的性能和功能。

测试和开发

在开发和测试阶段,SQLite 可以用作快速原型设计和测试的小型数据库。由于其零配置特性,开发者可以轻松地创建和管理数据库。

分布式数据库系统的缓存或中转存储

在一些分布式数据库系统中,SQLite 可以用作缓存层或中转存储,从而减少对主数据库的压力,并提高系统的整体性能。

SQLite 的限制

尽管 SQLite 具有许多优点,但在某些场景中也存在一些限制:

  1. 并发访问:SQLite 对并发写入操作支持有限,适合单用户或低并发场景。
  2. 存储容量:SQLite 的单个数据库文件最大为 140TB,但实际应用中,由于性能和管理上的考虑,适合较小的数据集。
  3. 功能:虽然 SQLite 支持大多数标准 SQL 功能,但不支持某些高级特性,如存储过程、用户定义函数(UDF)和某些类型的复杂查询。

SQLite 是一个强大且灵活的嵌入式数据库解决方案,适用于多种应用场景。从基本的数据库操作到高级功能,如事务、视图和触发器,SQLite 提供了一个完整的 SQL 数据库引擎,并且易于使用和集成。尽管存在一些限制,但对于大多数嵌入式和单用户应用来说,SQLite 是一个理想的选择。

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

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

相关文章

重生之“我打数据结构,真的假的?”--4.二叉树(无习题)

1.二叉树 1.1概念与结构 在树形结构中&#xff0c;我们最常⽤的就是⼆叉树&#xff0c;⼀棵⼆叉树是结点的⼀个有限集合&#xff0c;该集合由⼀个根结点 加上两棵别称为左⼦树和右⼦树的⼆叉树组成或者为空。 1. ⼆叉树不存在度⼤于 2 的结点 2. ⼆叉树的⼦树有左右之分&…

《梦醒蝶飞:释放Excel函数与公式的力量》20.2 教学材料的自动化处理

第20章&#xff1a;自动化教学辅助工具 20.2 教学材料的自动化处理 自动化处理教学材料是利用编程技术和工具&#xff0c;自动执行教学材料的生成、整理和分发等任务的过程。通过自动化&#xff0c;可以提高教学材料处理的效率&#xff0c;减少手动操作的时间&#xff0c;从而…

用Swagger进行后端接口测试的实战操作

目录 一.什么是Swagger&#xff1f; 二.Swagger的使用操作流程&#xff1a; 1.在pom.xml配置文件导入 Knife4j 的依赖&#xff1a; 2.在config配置类中加入 Knife4j 的相关配置并设置静态资源映射&#xff08;否则接口文档无法访问&#xff09;&#xff1a; 三.Swagger的四个…

InteliJ IDEA最新2024版下载安装与快速配置激活使用教程+jdk下载配置

第一步&#xff1a;下载ideaIC-2024.1.4 方法1&#xff1a;在线链接 IntelliJ IDEA – the Leading Java and Kotlin IDE (jetbrains.com) 选择社区版进行下载 方法2&#xff1a;百度网盘 链接&#xff1a;https://pan.baidu.com/s/1ydS6krUX6eE_AdW4uGV_6w?pwdsbfm 提取…

解决django与sqlite3不兼容报SQLite 3.9.0 or later is required错的问题

今天在尝试用pytest进行django的单元测试&#xff0c;pytest用的数据库是sqlite3&#xff0c;在window环境下测试得好好的&#xff0c;但是放到linux环境下就报错&#xff0c;具体是报django.core.exceptions.ImproperlyConfigured: SQLite 3.9.0 or later is required (found …

LabVIEW学习-LabVIEW处理带分隔符的字符串从而获取数据

带分隔符的字符串很好处理&#xff0c;只需要使用"分隔符字符串至一维字符串数组"函数或者"一维字符串数组至分隔符字符串"函数就可以很轻松地处理带分隔符地字符串。 这两个函数所在的位置为&#xff1a; 函数选板->字符串->附加字符串函数->分…

超声波俱乐部:AI应用大爆发前夜,场景、闭环与LLM进化

7月13日&#xff0c;第十九期超声波俱乐部内部分享会在北京望京举行&#xff0c;本期的主题是&#xff1a;AI应用大爆发前夜&#xff0c;场景、闭环与LLM进化。 到场的嘉宾有&#xff1a;超声波创始人杨子超&#xff0c;超声波联合创始人、和牛商业创始人刘思雨&#xff0c;豆…

html+css 边框滑动按钮效果

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享htmlcss 绚丽效果&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 文…

基于 HTML+ECharts 实现智慧工地数据可视化大屏(含源码)

构建智慧工地数据可视化大屏&#xff1a;基于 HTML 和 ECharts 的实现 智慧工地已成为建筑行业的新趋势。通过实时监控和数据分析&#xff0c;智慧工地可以提高施工效率、降低安全风险。本文将详细介绍如何利用 HTML 和 ECharts 实现一个功能强大的智慧工地数据可视化大屏。 源…

vue3前端开发-小兔鲜项目-sku的实现

vue3前端开发-小兔鲜项目-sku的实现&#xff01;这是一个会计学的特殊专业名词&#xff0c;可以理解为产品的型号&#xff0c;规格的货品计量单位。 它是一组数据的混合体。比如&#xff1a;尺寸&#xff0c;材料&#xff0c;品质&#xff0c;等等。组合在一起形成的一个混合数…

pikachu Fileinclusion(local)

随便选择一个都试试 发现url上数字会变 发现文件名确实是file1.php~file5.php 那么会不会还有别的burp抓包选中数字 设置6-100的爆破 strat attack 678异常还有个100也是 先改一下试试看 其他的会报错 但是通过这我们可以得到路径 先写一个 下一步 读取系统文件 windows系统肯定…

产品系统的UI暗色系和浅色系模式切换是符合人体视觉工程学的设计

视觉革命&#xff1a;UI设计中的暗夜与黎明 UI设计如同夜空中最亮的星辰&#xff0c;引领着用户穿梭于信息的海洋。而今&#xff0c;一场视觉革命正在悄然上演&#xff0c;它关乎于我们的眼睛&#xff0c;关乎于我们的体验——那就是产品系统的UI暗色系和浅色系模式的切换。如…

Git merge

Git merge 参考文档&#xff1a; https://marsishandsome.github.io/2019/07/Three_Way_Merge https://git-scm.com/docs/merge-strategies https://stackoverflow.com/questions/56889406/how-does-git-compare-two-files-while-merging Git merge的目标是合并changes&#x…

web小项目-曼波生日录(Servlet+JSP+MySQL)

效果演示&#xff1a; 当记录条数过多时会自动出现滚轮&#xff0c;数据不会超出紫框 数据库实时记录&#xff1a; 项目源代码以及所用到的资源&#xff1a; 链接: https://pan.baidu.com/s/1w0czmH9xBfetk7CZ7RNbtQ?pwd6666 提取码: 6666 复制这段内容后打开百度网盘手机App…

vue3+openLayers点击标记事件

<template><!--地图--><div class"distributeMap" id"distributeMap"></div> </template> <script lang"ts" setup> import { onMounted, reactive } from "vue"; import { Feature, Map, View }…

一款允许使用Docker部署本地托管的、基于 Web 的 PDF 操作工具

大家好&#xff0c;今天给大家分享的是一个基于Spring Boot开发的开源项目&#xff0c;旨在提供一个功能强大的基于Docker的本地托管PDF操作工具Stirling PDF。 项目介绍 Stirling-PDF是一个全面的PDF工具箱&#xff0c;适用于个人和企业用户&#xff0c;尤其对于那些重视数据…

华杉研发九学习日记17 正则表达式 异常

华杉研发九学习日记17 一&#xff0c;正则表达式 ^ $ 作用&#xff1a; 测试字符串内的模式(匹配) 例如&#xff0c;可以测试输入字符串&#xff0c;以查看字符串内是否出现电话号码模式或信用卡号码模式。这称为数据验证. 替换文本&#xff08;替换》 可以使用正则表达式来…

谷粒商城实战笔记-59-商品服务-API-品牌管理-使用逆向工程的前后端代码

文章目录 一&#xff0c; 使用逆向工程生成的代码二&#xff0c;生成品牌管理菜单三&#xff0c;几个小问题 在本次的技术实践中&#xff0c;我们利用逆向工程的方法成功地为后台管理系统增加了品牌管理功能。这种开发方式不仅能快速地构建起功能模块&#xff0c;还能在一定程度…

Elasticsearch 7.x入门学习-Java API操作

1 创建项目 在idea开发工具中创建Maven项目 修改 pom 文件&#xff0c;增加 Maven 依赖关系 <dependencies><dependency><groupId>org.elasticsearch</groupId><artifactId>elasticsearch</artifactId><version>7.8.0</versi…

MySQL学习(13):SQL优化:查看SQL语句性能的方法

1.查看SOL执行频率 MySQL客户端连接成功后&#xff0c;通过如下指令&#xff0c;可以查看当前数据库的insert、update、delete、select的访问频次: show global status like Com_______; #查看全局。后面是7个下划线 使用效果如下&#xff1a; 可以看到各条命令的使用次数。…