SQLite本地数据库的简介和适用场景——集成SpringBoot的图文说明

前言:现在项目普遍使用的数据库都是MySQL,而有些项目实际上使用SQLite既足矣。在一些特定的项目中,要比MySQL更适用。
这一篇文章简单的介绍一下SQLite,对比MySQL的优缺点、以及适用的项目类型和集成SpringBoot


1. SQLite 简介

SQLite 是一种轻量级、嵌入式的关系型数据库管理系统,具有以下特点:

  1. 单文件存储:所有的数据库对象(如表、索引、视图等)都存储在一个普通的文件中,便于移动和备份。
  2. 无服务器架构:无需独立的服务器进程,数据库引擎直接嵌入应用程序中运行,极大地简化了部署。
  3. 零配置:不需要安装或配置,直接拷贝文件即可使用。
  4. 支持事务:完全支持 ACID(原子性、一致性、隔离性、持久性)事务机制,保证数据完整性。
  5. 跨平台:SQLite 数据库文件可以在不同操作系统之间无缝迁移。
  6. 开放源码:SQLite 是开源的,遵循公共领域协议,免费供个人和商业项目使用。

2. 对比MySQL的相对优缺点

1. SQLite 的相对优点
  1. 轻量级与便捷性
    • 无服务器架构:SQLite 不需要安装服务器,也无需运行单独的服务程序,直接嵌入到应用程序中。
    • 零配置:使用时无需复杂的配置,只需引入库文件即可开始操作。
  2. 单文件存储
    • SQLite 的数据库存储为单个文件,便于迁移和备份。
    • 适合嵌入式设备或小型应用程序。
  3. 资源占用小
    • SQLite 的代码库很小(通常小于 1MB),对系统资源的占用极低。
    • 特别适合内存和存储空间有限的设备(如 IoT 设备、移动应用)。
  4. 跨平台兼容性
    • SQLite 的数据库文件在不同操作系统之间完全兼容,无需额外调整。
  5. 易用性高
    • 适合原型设计和快速开发,减少环境配置成本。
    • 提供简单的 API,适合初学者和小型项目。
2. SQLite 的相对缺点
  1. 性能限制
    • 不擅长处理高并发场景,尤其是多写入操作时可能出现锁定问题。
    • 在大型数据集(如 GB 级或更大数据)和复杂查询上性能不如 MySQL。
  2. 功能限制
    • 不支持存储过程、触发器(功能较简单)、视图等高级功能。
    • 不具备复杂的权限管理机制,没有用户角色划分,适合单用户场景。
  3. 安全性较低
    • SQLite 没有内置的用户管理和身份验证机制,依赖应用程序自身控制访问权限。
    • 不适合需要高安全性或多用户权限管理的场景。
  4. 缺乏扩展性
    • SQLite 设计为单机数据库,不支持分布式架构或主从复制。
    • 无法满足大规模企业级应用的需求。
  5. 并发能力不足
    • SQLite 采用数据库级别锁,写入操作时会阻塞其他操作,无法处理高并发写入需求。
    • 相比 MySQL 的行级锁,事务管理能力较弱。
  6. 数据类型较少
    • 没有date、decimal、json等数据类型。(有处理时间的函数)

3. 应用场景

  • 嵌入式开发:广泛用于移动应用(如 Android 和 iOS)、IoT 设备等。
  • 桌面软件:如浏览器(Google Chrome、Firefox)、媒体播放器等。
  • 快速开发和测试:适合小型应用或开发中的原型设计。
  • 只读数据库:适合存储小型静态数据(如配置文件或数据字典)。
  • 做配置文件:一些桌面端、APP、linux应用服务的配置文件。

4. 集成SpringBoot

1. 使用idea快速创建一个SpringBoot项目

2. 在pom.xml<dependencies>中添加sqlite的依赖
<!-- spring-boot-starter-jdbc 和 SQLite 驱动 sqlite-jdbc -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency><groupId>org.xerial</groupId><artifactId>sqlite-jdbc</artifactId><version>3.45.3.0</version>
</dependency>
3. 在application.yaml中添加sqlite的配置
spring:datasource:type: com.zaxxer.hikari.HikariDataSourcedriver-class-name: org.sqlite.JDBCurl: "${database.jdbc}:${database.path}"# 分别单独指定jdbc和path方便获取对应的值
database:jdbc: "jdbc:sqlite"path: "database.db"
4. 配置DataSourceConfig,方便全局使用
import ...@Configuration
@Slf4j
public class DataSourceConfig {@Value("${database.jdbc}")private String jdbc;@Value("${database.path}")private String path;@Value("${spring.datasource.driver-class-name}")private String driverClassName;@Value("${project.version}")private String projectVersion;@Autowiredprivate ServletContext servletContext;@SneakyThrows@Beanpublic DataSource dataSource() {/**1、指定sqlite数据文件的具体位置,或者相对位置。2、初始化时,如果文件不存在、则创建文件、创建相应的数据表(初始化数据库)。3、配置dataSource数据源,方便全局使用。4、其他逻辑...**/}}
5. Application启动类配置
/* 排除自动配置数据源 */
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
  • 参数exclude = {DataSourceAutoConfiguration.class}
    默认情况下,Spring Boot 会根据类路径中的依赖自动配置数据源(比如 HikariDataSource)。不需要数据库或手动配置数据源,可以通过 exclude 参数排除自动配置类。
    这里排除了 DataSourceAutoConfiguration,表示应用不会自动配置数据源。
6. 运行SpringBoot项目
/* 控制台输出 */
Tomcat started on port 8080 (http) with context path ''
Started Application in 3.21 seconds (process running for 4.6)
=================== spring boot 启动成功! =====================

  • 在项目的目录下已经生成了SQLite的数据文件,至此SpringBoot集成SQLite完成

结束语:SQLite 的设计目标是轻量高效易用方便迁移,适合需要嵌入式数据库的应用程序和小型项目。

—— 如果觉得文章有用💪,点个赞,支持一下👏!——

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

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

相关文章

游戏引擎学习第62天

回顾 我们目前正在开发一把虚拟剑&#xff0c;目的是让角色可以用这把剑进行攻击。最初的工作中&#xff0c;我们使用了一个摇滚位图作为虚拟剑的模型&#xff0c;并且实现了一个基本的功能&#xff1a;角色可以丢下剑。但这个功能并没有达到预期的效果&#xff0c;因为我们想…

spring专题笔记(六):bean的自动装配(自动化注入)-根据名字进行自动装配、根据类型进行自动装配。代码演示,通俗易懂。

目录 一、根据名字进行自动装配--byName 二、根据类型进行自动装配 byType 本文章主要是介绍spring的自动装配机制&#xff0c; 用代码演示spring如何根据名字进行自动装配、如何根据类型进行自动装配。代码演示&#xff0c;通俗易懂。 一、根据名字进行自动装配--byName Us…

petalinux 中 cmake 需要用到的环境变量

自定义修改部分环境变量, 实测可用

深入解析MySQL索引结构:从数组到B+树的演变与优化

前言&#xff1a; 在数据库查询中&#xff0c;索引是一种关键的性能优化工具。然而&#xff0c;索引的失效可能导致查询效率大幅下降。为了更好地理解索引的工作原理及规避其失效&#xff0c;深入了解索引结构的演变过程尤为重要。 MySQL 的索引数据结构从简单到复杂&#xff0…

43. Three.js案例-绘制100个立方体

43. Three.js案例-绘制100个立方体 实现效果 知识点 WebGLRenderer&#xff08;WebGL渲染器&#xff09; WebGLRenderer是Three.js中最常用的渲染器之一&#xff0c;用于将3D场景渲染到网页上。 构造器 WebGLRenderer(parameters : Object) 参数类型描述parametersObject…

Python vs PHP:哪种语言更适合网页抓取

本文将比较 Python 和 PHP&#xff0c;以帮助读者确定哪种语言更适合他们的需求。文章将探讨两种语言的优点和缺点&#xff0c;并根据读者的经验水平分析哪种语言可能更容易上手。接下来&#xff0c;文章将深入探讨哪种语言在抓取网页数据方面更胜一筹。 简而言之&#xff0c;…

python+reportlab创建PDF文件

目录 字体导入 画布写入 创建画布对象 写入文本内容 写入图片内容 新增页 画线 表格 保存 模板写入 创建模板对象 段落及样式 表格及样式 画框 图片 页眉页脚 添加图形 构建pdf文件 reportlab库支持创建包含文本、图像、图形和表格的复杂PDF文档。 安装&…

打造两轮差速机器人fishbot:从零开始构建移动机器人

大家好&#xff0c;我是梦笔生花&#xff0c;我们一起来动手创建一个两轮差速的移动机器人fishbot。 机器人除了雷达之外&#xff0c;还需要IMU加速度传感器以及可以驱动的轮子&#xff0c;我们曾介绍过机器人学部分&#xff0c;曾对两差速模型进行过介绍&#xff0c;所以我们…

Python函数(十二):函数的创建和调用、参数传递、返回值

前言&#xff1a;在编程的世界里&#xff0c;函数是一种基本的构建块&#xff0c;它允许我们将代码封装成可重复使用的单元。在Python中&#xff0c;函数的使用尤为重要&#xff0c;因为它不仅有助于代码的模块化&#xff0c;还提高了代码的可读性和可维护性。本章节&#xff0…

UE5 崩溃问题汇总!!!

Using bundled DotNet SDK version: 6.0.302 ERROR: UnrealBuildTool.dll not found in "..\..\Engine\Binaries\DotNET\UnrealBuildTool\UnrealBuildTool.dll" 在你遇到这种极奇崩溃的BUG &#xff0c;难以解决的时候。 尝试了N种方法&#xff0c;都不行的解决方法。…

nginx Rewrite 相关功能

一、Nginx Rewrite 概述 定义 Nginx 的 Rewrite 模块允许对请求的 URI 进行重写操作。它可以基于一定的规则修改请求的 URL 路径&#xff0c;然后将请求定向到新的 URL 地址&#xff0c;这在很多场景下都非常有用&#xff0c;比如实现 URL 美化、网站重构后的 URL 跳转等。主要…

GA-Kmeans-Transformer时序聚类+状态识别组合模型

创新研究亮点&#xff01;GA-Kmeans-Transformer时序聚类状态识别组合模型 目录 创新研究亮点&#xff01;GA-Kmeans-Transformer时序聚类状态识别组合模型效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.创新研究亮点&#xff01;GA-Kmeans-Transformer时序聚类状态识…

最新的强大的文生视频模型Pyramid Flow 论文阅读及复现

《PYRAMIDAL FLOW MATCHING FOR EFFICIENT VIDEO GENERATIVE MODELING》 论文地址&#xff1a;2410.05954https://arxiv.org/pdf/2410.05954 项目地址&#xff1a; jy0205/Pyramid-Flow&#xff1a; 用于高效视频生成建模的金字塔流匹配代码https://github.com/jy0205/Pyram…

阻塞队列BlockingQueue实战及其原理分析

1. 阻塞队列介绍 1.1 队列 是限定在一端进行插入&#xff0c;另一端进行删除的特殊线性表。先进先出(FIFO)线性表。允许出队的一端称为队头&#xff0c;允许入队的一端称为队尾。 数据结构演示网站&#xff1a;https://www.cs.usfca.edu/~galles/visualization/Algorithms.ht…

hadoop搭建

前言 一般企业中不会使用master slave01 slave02来命名 vmware创建虚拟机 打开vmware软件&#xff0c;新建虚拟机 典型 稍后安装系统 选择centos7 虚拟机名称和安放位置自行选择&#xff08;最小化安装消耗空间较少&#xff09; 默认磁盘大小即可 自定义硬件 选择centos7的i…

测试 - 1 ( 9000 字详解 )

一&#xff1a; 测试入门 测试是指运用特定的方法、手段或工具&#xff0c;对某一对象进行验证、检查或评估&#xff0c;判断其是否符合预期标准或目标。例如&#xff0c;修理好一盏灯后通过按开关测试其是否正常工作&#xff1b;通过一次数学测验评估学生对代数知识的掌握程度…

【MATLAB第110期】#保姆级教学 | 基于MATLAB的PAWN全局敏感性分析方法(无目标函数)含特征变量置信区间分析

【MATLAB第110期】#保姆级教学 | 基于MATLAB的PAWN全局敏感性分析方法&#xff08;无目标函数&#xff09;含特征变量置信区间分析 一、介绍 PAWN&#xff08;Probabilistic Analysis With Numerical Uncertainties&#xff09;是一种基于密度的全局敏感性分析&#xff08;Gl…

DX12 快速教程(2) —— 渲染天蓝色窗口

快速导航 新建项目 "002-DrawSkyblueWindow"DirectX 12 入门1. COM 技术&#xff1a;DirectX 的中流砥柱什么是 COM 技术COM 智能指针 2.创建 D3D12 调试层设备&#xff1a;CreateDebugDevice什么是调试层如何创建并使用调试层 3.创建 D3D12 设备&#xff1a;CreateD…

【合作原创】使用Termux搭建可以使用的生产力环境(八)

前言 在上一篇【合作原创】使用Termux搭建可以使用的生产力环境&#xff08;七&#xff09;-CSDN博客中我们讲到了安装百度网盘、VS Code还有java&#xff0c;这篇我打算讲一下最后的编程&#xff0c;还有输入法相关问题解决。众所周知我的本职工作是Java程序猿&#xff0c;因…

VLMs之Gemma 2:PaliGemma 2的简介、安装和使用方法、案例应用之详细攻略

VLMs之Gemma 2&#xff1a;PaliGemma 2的简介、安装和使用方法、案例应用之详细攻略 导读&#xff1a;2024年12月4日&#xff0c;PaliGemma 2是一个基于Gemma 2系列语言模型的开源视觉语言模型 (VLM) 家族。PaliGemma 2 通过提供一个规模化、多功能且开源的VLM家族&#xff0c;…