【数据库】sqlite

news2024/9/25 7:11:44

文章目录

    • 1. 基本概述
    • 2. 主要特点
    • 3. 应用场景
    • 4. 优缺点
    • 5. 基本使用示例
    • 6. 在编程语言中的使用
      • 连接到 SQLite 数据库(如果文件不存在会自动创建)
      • 创建表
      • 插入数据
      • 提交事务
      • 查询数据
      • 关闭连接
    • 7. 总结

SQLite 是一个轻量级的关系型数据库管理系统(RDBMS),它以其简洁、高效和易用性在众多应用场景中得到广泛应用。

1. 基本概述

无服务器架构:SQLite 不需要独立的服务器进程或系统来运行,它是一个嵌入式数据库,直接集成在应用程序中。
自包含:所有数据库功能都包含在一个单一的库文件中,简化了部署和管理。
零配置:无需复杂的配置过程,开箱即用。

2. 主要特点

轻量级:SQLite 库的大小通常在几百 KB 左右,非常适合资源受限的环境。
跨平台:支持多种操作系统,包括 Windows、macOS、Linux、iOS 和 Android。
事务支持:完全支持 ACID(原子性、一致性、隔离性、持久性)事务,确保数据的可靠性。
标准 SQL 支持:支持大部分标准 SQL 语法,易于学习和使用。
高性能:在读取操作上表现出色,适用于大多数中小型应用场景。

3. 应用场景

移动应用:广泛用于 Android 和 iOS 应用中,作为本地存储解决方案。
桌面应用:如浏览器(SQLite 用于存储书签、历史记录等)、媒体播放器等。
嵌入式系统:适用于物联网设备、智能家居等需要本地数据存储的设备。
测试和开发:常用于开发阶段的轻量级数据库需求,方便快速迭代。

4. 优缺点

优点
简单易用:无需复杂的安装和配置,适合快速开发和部署。
高效:对于读多写少的应用场景,性能表现优异。
便携性:数据库文件是一个单独的文件,易于备份、迁移和共享。
缺点
并发性有限:在高并发写操作的场景下,性能可能受限。
功能有限:相比于大型数据库(如 MySQL、greSQL),一些高级功能(如存储过程、复杂权限管理)不支持或支持有限。
规模限制:适合中小型数据集,对于极大规模的数据存储和复杂查询可能不适合。

5. 基本使用示例

以下是使用 SQLite 的基本操作示例,使用命令行工具 sqlite3:

创建数据库和表

-- 创建一个名为 example.db 的数据库并进入交互模式
sqlite3 example.db
-- 创建一个用户表
CREATE TABLE users (
    id INTEGER PRIMARY KEY,
    name TEXT NOT NULL,
    email TEXT UNIQUE NOT NULL
);

插入数据

INSERT INTO users (, email) VALUES ('张三', 'zhangsan@example.com');
INSERT INTO users (, email) VALUES ('李四', '@example.com');

查询数据

SELECT * FROM users;

更新数据

UPDATE users SET email = 'zhangsan_new@example.com' WHERE id = 1;

删除数据

DELETE FROM users WHERE id = 2;

关闭数据库

.exit

6. 在编程语言中的使用

SQLite 支持多种编程语言的接口,如 Python、C/C++、 等。以下是使用 Python 操作 SQLite 的简单示例:

import sqlite3

连接到 SQLite 数据库(如果文件不存在会自动创建)

conn = sqlite3.connect('example.db')
cursor = conn.cursor()

创建表

cursor.execute('''
    CREATE TABLE IF NOT EXISTS users (
        id INTEGER PRIMARY KEY,
        name TEXT NOT NULL,
        email TEXT UNIQUE NOT NULL
    )
''')

插入数据

cursor.execute('INSERT INTO users (, email) VALUES (?, ?)', ('王五', 'wu@example.com'))

提交事务

conn.commit()

查询数据

cursor.execute('SELECT * FROM users')
rows = cursor.fetchall()
for row in rows:
    print(row)

关闭连接

conn.close()

7. 总结

SQLite 以其轻量级、易用和高效的特性,成为了众多应用程序的首选数据库解决方案。无论是移动开发、桌面应用,还是嵌入式系统,SQLite 都能提供可靠的本地数据存储支持。虽然在某些高并发或复杂需求场景下存在限制,但对于大多数中小型项目来说,SQLite 是一个非常理想的选择。

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

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

相关文章

风力发电机叶片表面缺陷识别检测数据集yolo数据集 共7000张

风力发电机叶片表面缺陷识别检测数据集yolo数据集 共7000张 风力发电机叶片表面缺陷识别数据集(Wind Turbine Blade Defects Recognition Dataset, WTBDRD) 摘要 WTBDRD 是一个专门为风力发电机叶片表面缺陷识别而设计的数据集,旨在为相关领…

【目标检测】隐翅虫数据集386张VOC+YOLO

隐翅虫数据集:图片来自网页爬虫,删除重复项后整理标注而成 数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):386 标注…

Oracle逻辑备份脚本【生产环境适用】

1 说明 从Oracle10g开始,引入了数据泵(Data Pump),是一种高效的数据传输工具,它通过导出(Export)和导入(Import)的方式帮助用户迁移数据。 在Oracle的产品设计中&#…

IntraWeb开发Web网站时对数据库“增、删、改、查”的操作

delphi源代码:示例两列布局带顶部汉堡菜单,对数据库“增、删、改、查”的操作(兼容电脑与手机) 功能:交互式网页,两列布局,顶部汉堡菜单,点击汉堡图标关闭左侧栏,这里演示…

责任链模式优化 文章发布的接口(长度验证,敏感词验证,图片验证等环节) 代码,示例

需求:后端需要提供一个文章发布的接口,接口中需要先对文章内容进行如下校验,校验通过后才能发布 1. 文章长度不能超过1万个字符 2. 不能有敏感词 3. 文章中图片需要合规 责任链相当于一个链条一样,链条上有很多节点,节…

Flask学习之项目搭建

一、项目基本结构 1、 exts.py 存在的目的:在Python中,如果两个或更多模块(文件)相互导入对方,就会形成导入循环。例如,模块A导入了模块B,同时模块B又导入了模块A,这就会导致导入循环。 比如在这个项目中…

拦截器filter

使用拦截器对请求进行拦截,查看请求头是否携带token 可以看到,拦截器引入了web的依赖 前端的请求会经过网关(gateway),网关用的是netty服务器,会和web默认的tomcat服务器冲突,但是前端过来的请求…

SMTP/IMAP服务发在线邮件时要用到

SMTP/IMAP服务 require PHPMailerAutoload.php; // 或 require class.phpmailer.php;// 创建实例 $mail new PHPMailer();// 设定邮件服务器 $mail->isSMTP(); $mail->Host smtp.example.com; // 邮件服务器地址 $mail->SMTPAuth true; $mail->Username your…

Golang | Leetcode Golang题解之第434题字符串中的单词数

题目: 题解: func countSegments(s string) (ans int) {for i, ch : range s {if (i 0 || s[i-1] ) && ch ! {ans}}return }

Redis面试笔记

1.什么是Redis 简单来说 redis 就是一个数据库,不过与传统数据库不同的是 redis 的数据是存在内存中的,所以读写速度非常快,因此 redis 被广泛应用于缓存方向。另外,redis 也经常用来做分布式锁。redis 提供了多种数据类型来支持…

如何在算家云搭建DiffSynth-Kolors-Painter(图像生成)

一、DiffSynth-Kolors-Painter简介 DiffSynth 画板提供了 Prompt 分区控制技术,可以通过创建图层、调整不同的提示(Prompt)精细地控制画面的每一部分,影响画面的特定区域,从而实现对画面的精细操控,实现了…

LobeChat:使用服务端数据库部署 - Docker+NextAuth(github)+腾讯云

总流程 Docker部署 身份验证服务-NextAuth github S3存储服务 腾讯云COS 1. 安装Docker brew install docker --cask2. 创建pgvector容器(PostgresSQL) docker run --name [myPgvector] -p 5432:5432 -e POSTGRES_PASSWORD[pwd] -d -e POSTGRES_USER[username] pgvector/…

MySQL—存储过程详解

基本介绍 存储过程和函数是数据库中预先编译并存储的一组SQL语句集合。它们的主要目的是提高代码的复用性、减少数据传输、简化业务逻辑处理,并且一旦编译成功,可以永久有效。 存储过程和函数的好处 提高代码的复用性:存储过程和函数可以在…

【NPL】daydayup基本概念,词嵌入

NLP基础 基本概念 NLP,自然语言处理,目标是让计算机能够理解、解释、生成人类语言的数据。包括语言理解,语言生成,机器翻译,情感分享,语音识别,语音合成等 应用方向 自然语言理解 情感分析&a…

Python办公自动化案例:实现XMind文件转换成Excel文件

案例:实现XMind文件转换成Excel文件 将XMind文件转换为Excel文件的过程可以通过几个步骤来实现,主要涉及到读取XMind文件,解析其内容,然后创建一个Excel文件并将解析的内容写入。以下是一个简化的Python脚本,展示了如何使用xmindparser库来解析XMind文件,并使用pandas库…

搜索引擎简介

搜索引擎架构 整个搜索引擎分为三个系统 爬虫系统 索引系统 线上搜素服务 爬虫系统 爬虫分为两个阶段: 第一阶段:根据目标网站的列表页,爬对应的文档 URL 第二阶段:根据文档 URL,下载文档内容 触发器&#xff1…

多级目录SQL分层查询

需求&#xff1a;有多级目录&#xff0c;而目录的层级是不固定的&#xff0c;如下图所示&#xff1a; 数据结构&#xff1a; sql语句&#xff1a; <select id"getList" resultType"com.hikvision.idatafusion.dhidata.bean.vo.knowledgebase.KnowledgeBaseT…

基于SSM的“银发在线教育云平台”的设计与实现(源码+数据库+文档)

基于SSM的“银发在线教育云平台”的设计与实现&#xff08;源码数据库文档) 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SSM 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 系统功能结构图 首页页面图 健身养生详情页面 在线课堂界面 …

C++ | Leetcode C++题解之第434题字符串中的单词数

题目&#xff1a; 题解&#xff1a; class Solution { public:int countSegments(string s) {int segmentCount 0;for (int i 0; i < s.size(); i) {if ((i 0 || s[i - 1] ) && s[i] ! ) {segmentCount;}}return segmentCount;} };

一种单目标A*算法设计与实现

一种单目标A*算法设计与实现 作者&#xff1a;吴屏珊 最近在学习简单的单目标A*算法&#xff0c;其中在CSDN上阅读到的一篇博文给了我很大启发&#xff0c;于是在该博文的基础上&#xff0c;笔者记录了一点自己对于A*算法的体会和感悟。原文链接 目录 文章目录 一种单目标A*…