SQLite简单介绍

news2025/2/3 16:05:47

一.简单介绍

SQLite是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的,而且已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口 。

SQLite第一个Alpha版本诞生于2000年5月。至2019年已经有19个年头,SQLite也迎来了一个版本 SQLite 3已经发布 。

二.具体安装细节

2.1 下载

下载地址 :https://www.sqlite.org/download.html
具体下载window版本的即可
在这里插入图片描述

2.2 解压

解压文件后,我们进行点击操作
Shift + 右键点击 sqlite3.exe 所在⽬录, 打开 powershell

在这里插入图片描述

2.3 sqlite的使用

对数据库的操作

  1. 创建数据库:sqlite3 database_name.db
  2. 删除数据库:DROP DATABASE database_name.db

对表的操作

  1. 创建表
语法:
		CREATE TABLE 表名
		(
				列名1	数据类型	“约束”(有可无)
				列名2	数据类型	“约束”(有可无)
				列名3	数据类型	“约束”(有可无)
				...
		);//注意,SQL语句要以分号结尾
数据类型:
  1. 删除表
语法:
		DROP TABLE 表名;
  1. 修改表结构
重命名:
	ALTER TABLE 旧表名 rename to 新表名;
增加一列:
	ALTER TABLE 表名 add column 列名 数据类型
  1. 向表插入数据
语法:
	INSERT INTO 表名 VALUES(1,值2,值3...);//给所有的列插入数据,有多少列就要填多少值。
	INSERT INTO 表名 VALUE(列名1,列名2....) VALUE (1,值2... );//给指定列插入数据

  1. 修改表内的数据
UPDATE 表名 set 列名 = 新值,...;
UPDATE 表名 set 列名 = 新值,...WHERE 条件;//条件用来定位要修改的某些行
条件:
	列名 运算符 值
	运算符: = 	!= 	>	 >=	 <=
	如果有多个条件,可以用andor连接
eg:
	update stu set age = 21;
	update stu set age = 30 where num = 1001;
	update stu set age = 30 where num > 60 and num < 999;
  1. 删除表中的所有数据
DELETE FROM  表名;//删除表中所有的数据
DELETE FROM 表名 WHERE 条件;//删除满足条件数据
	eg:
		delete from stu;
		delete from stu where num = 1003;

  1. select 数据查询
语法:
	SELECT	列名1...FROM 表名;
	SELECT *FROM 表名;//查询整个表的数据
	SELECT *FROM 表名 where 条件;//查询整个表的数据
	eg:
		insert into stu1(stu_num,stu_name,age,,addr) select stu_num,stu_name,age,addr from stu;//从stu表中插入数据,然后插入到stu1表中

  1. 高级查询
模糊查询
	列名	like	通配符	(_%)
	_:	匹配单个字符
	&:匹配任意单个字符
	eg:
		select *from stu where name like 'wang_';
		select	*from stu where name like	'%wang%'
排序:
	按指定的列名进行排序
	order by 列名 asc/desc;//asc:升序	desc:降序
		eg:
			select *from stu order by age desc;//根据年龄降序排序
	限制记录条数
		limit 数字
				eg:
					select *from stu limit 2;//查看表中的前两条记录
	排序+限制
		eg:
			select *from stu order by age desc limit 1;//查看年龄最大的记录
	聚合函数
		cout(*)	//统计记录数量
		sum(列名)	//计算给定列的总和
		avg(列名)		//计算给定列的平均值
		min(列名)		//计算给定列的最小值
		max(列名)	//计算给定列*的最大值
	eg:
		select	cout(*)  from stu;
		select max(age)-min(age) from stu;
	别名
		eg:
			select num AS 学号,name AS	姓名 from stu;
	分组:
		group by
			eg:
				select age,cout(*) from stu group by age;//查询每个年龄的人数
	范围查询:
		between ... and ...
			eg:	
				select *from stu where age between 10 and 20;
	去重:
		distinct
			eg:
				select distinct age from stu;
	子查询:
		in(值,...)
		in(select ...)
			eg:
				select *from stu where age in (18,20,25);
				select *from stu where age in (select age from stu where age < 30);		
		★★★★★★多表联接
			select	列名,...1,表2...where 条件
			select 列名,... form 表1	join2 on	联接条件  ... where	过滤条件;
					eg:
						学生表:	
						学号 	姓名 	年龄		班级		学校	
						...
						create table t_stu(num int primary key, name text,age int,class int school int);
						intsrt into t_stu values(1001,'wb1',18,100101,2001);
						insert into t_stu values(1002,'wb2',19,100101,2001);
						insert into t_stu values(1003.'wb3',20,100101,2002);
						学校表:
						编号		校名		电话		地址
						...
						create table t_school(num int primary key,name text, tel text,addr text);
						insert into t_school values(2001,'first',010-123456,'changsha');
						insert into t_school values(2002,'second',010-0101011,'shanghai');
				需求:
					查询学生的学号,姓名,学校名
						select  t_stu.num,t_stu.name,t_school,name from t_stu,t_school);
				===》学生表中的每一行都与学校表中的每一行进行联结,结果称之为 笛卡尔积
				此时,需要指明两个表联结条件,在上述表中,联结条件是 学校的编号相同
	两种联结写法:
		第一种: select t_stu,num, t_stu.name,t_school.name from t_stu,t_school where	t_stu.school = t_school.num;
		第二种:select t_stu.num,t_stu.name,t_school.name from t_stu join t_school on t_stu.school = t_school.num;
		select t_stu.num,t_stu.name,t_school.name from t_stu join t_school on t_stu.school = t_school.num where t_stu.num = 1002;

2.4 怎么使用jdbc连接sqlite

事先创建一个表

CREATE TABLE test(id int primary key,name varchar(20));

然后我们开始对sqlite进行基本的操作.
1.首先引入sqlite依赖
进入maven官网,导入依赖
https://mvnrepository.com/artifact/org.xerial/sqlite-jdbc/3.42.0.0

<!-- https://mvnrepository.com/artifact/org.xerial/sqlite-jdbc -->
<dependency>
    <groupId>org.xerial</groupId>
    <artifactId>sqlite-jdbc</artifactId>
    <version>3.42.0.0</version>
</dependency>

2.编写数据库连接代码

public class ConnectionTest {
    public static void main(String[] args) throws SQLException {
//        testInsert();
        testSelect();
    }

    private static void testSelect() throws SQLException {
        //1.创建数据源
        DataSource dataSource=new SQLiteDataSource();
        ((SQLiteDataSource)dataSource).setUrl("jdbc:sqlite://d:/ITsoftware/sqlite-tools-win32-x86-3420000/test.db");
        //2.建立连接
        Connection connection= dataSource.getConnection();
        //3.构造SQL语句
        String sql="select * from test";
        //4.执行SQL语句
        PreparedStatement statement=connection.prepareStatement(sql);
        ResultSet resultSet=statement.executeQuery();
        //5.遍历结果集合
        while (resultSet.next()){
            int id=resultSet.getInt("id");
            String name=resultSet.getString("name");
            System.out.println("id "+id +" "+ name);
        }
        //6.释放资源
        statement.close();
        resultSet.close();
        connection.close();

    }

    private static void testInsert() throws SQLException {
        //1.创建数据源 Datasource
        DataSource dataSource=new SQLiteDataSource();
        ((SQLiteDataSource)dataSource).setUrl("jdbc:sqlite://d:/ITsoftware/sqlite-tools-win32-x86-3420000/test.db");
        //2.建立连接
        Connection connection=dataSource.getConnection();
        //3.构造Sql语句
        String sql ="insert into test values(?,?)";
        //4.执行Sql预期
        PreparedStatement statement=connection.prepareStatement(sql);
        statement.setInt(1,11);
        statement.setString(2,"李四");
        statement.executeUpdate();
        //5.释放资源
        statement.close();
        connection.close();

    }

}

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

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

相关文章

CC-TAIX01 HONEYWELL 霍尼韦尔连接工厂热智商远程监测系统

CC-TAIX01 HONEYWELL 霍尼韦尔连接工厂热智商远程监测系统 -霍尼韦尔宣布霍尼韦尔连接工厂热智商,一种基于云的远程监测系统,旨在监测和管理关键的热过程数据。这是霍尼韦尔资产绩效管理(APM)投资组合的一部分。 热智商是工业和商业热应用的远程监测解决方案。它将燃烧设备连…

51单片机热水器温度控制系统仿真设计( proteus仿真+程序+原理图+报告+讲解视频)

51单片机热水器温度控制系统仿真设计 1.主要功能&#xff1a;2.仿真3. 程序代码4. 原理图5. 设计报告6. 设计资料内容清单 &&下载链接 51单片机热水器温度控制系统仿真设计( proteus仿真程序原理图报告讲解视频&#xff09; 仿真图proteus7.8及以上 程序编译器&#x…

OSCS 安全周报第 58 期:VMware Aria Operations SSH 身份验证绕过漏洞 (CVE-2023-34039)

​ 本周安全态势综述 OSCS 社区共收录安全漏洞 3 个&#xff0c;公开漏洞值得关注的是 VMware Aria Operations SSH 身份验证绕过漏洞( CVE-2023-34039 )、Apache Airflow Spark Provider 反序列化漏洞( CVE-2023-40195 )。 针对 NPM 仓库&#xff0c;共监测到 324 个不同版本…

Activiti7进阶

Activiti进阶 一、流程实例 什么是流程实例 流程实例&#xff08;ProcessInstance&#xff09;代表流程定义的执行实例。 一个流程实例包括了所有的运行节点。我们可以利用这个对象来了解当前流程实例的进度等信息。 例如&#xff1a;用户或程序按照流程定义内容发起一个流程&a…

鸿鹄工程项目管理系统em Spring Cloud+Spring Boot+前后端分离构建工程项目管理系统

Java版工程项目管理系统 Spring CloudSpring BootMybatisVueElementUI前后端分离 功能清单如下&#xff1a; 首页 工作台&#xff1a;待办工作、消息通知、预警信息&#xff0c;点击可进入相应的列表 项目进度图表&#xff1a;选择&#xff08;总体或单个&#xff09;项目显…

JavaWeb知识梳理(后端部分)

JavaWeb 静态web资源&#xff08;如html 页面&#xff09;&#xff1a;指web页面中供人们浏览的数据始终是不变。 动态web资源&#xff1a;指web页面中供人们浏览的数据是由程序产生的&#xff0c;不同时间点访问web页面看到的内容各不相同。 静态web资源开发技术&#xff1…

NAT地址转换,路由器作为出口设备,实现负载分担

路漫漫其修远兮&#xff0c;吾将上下而求索 一个善于创造的人&#xff0c;一定是一个善于分享的人。 今天整理了一个实验&#xff0c;具备NAT地址转换&#xff0c;路由器作为出口设备&#xff0c;实现负载分担&#xff0c;实现路由策略 目录 实验图 实验要求 实验配置 基…

Python Tkinter Multiple Windows 教程

一、说明 在这个Python Tkinter教程中&#xff0c;我们将学习如何在Python Tkinter中创建多个窗口&#xff0c;我们还将介绍与多个窗口相关的不同示例。而且&#xff0c;我们将介绍这些主题。 Python Tkinter multiple windows使用多个窗口的 Python Tkinter 用户注册Python Tk…

Java“牵手”唯品会商品详情数据,唯品会商品详情API接口,唯品会API接口申请指南

唯品会平台商品详情接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取唯品会商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片等详细信息 。 获取商品详情接口API是一种用于获取电商平台上商品详情数据的接口&#xff0c;…

华为Mate 60系列安装谷歌服务框架,安装Play商店,Google

华为Mate 60 Pro悄悄的上架。但是却震撼市场的强势登场,Mate 60系列默认搭载的就是鸿蒙4.0。那么mate 60加上4.0是否可以安装谷歌服务框架呢&#xff1f;本机到手经过测试是可以安装的&#xff0c;但是在解决play非保护机制认证还通知这个问题上,他和鸿蒙3.0是不一样的。如果我…

Notepad++下载安装

自己在 找Notepad发现网上的网址参差不齐&#xff0c;自己找到的一个不错下载链接见文末&#xff01; Notepad 是一个免费的代码编辑器&#xff0c;专为在微软 Windows 环境下使用。它是一个开源项目&#xff0c;采用 GPL 许可证&#xff0c;并使用 C 编程语言结合 Win32 API 和…

AI绘画:StableDiffusion实操教程-完美世界-魔女(附高清图下载)

前段时间我分享了StableDiffusion的非常完整的教程&#xff1a;“AI绘画&#xff1a;Stable Diffusion 终极宝典&#xff1a;从入门到精通 ” 尽管如此&#xff0c;还有读者反馈说&#xff0c;尽管已经成功安装&#xff0c;但生成的图片与我展示的结果相去甚远。真实感和质感之…

SW - 3D打印时遇到的审核问题(模型中存在多个壳体)

文章目录 SW - 3D打印时遇到的审核问题(模型中存在多个壳体)概述在.step中查看实体数量在.SLDPRT中查看实体数量备注END SW - 3D打印时遇到的审核问题(模型中存在多个壳体) 概述 给一个小PCB做了一个小壳子(为了使用安全和修护方便), 初步检查了一下, 没看出啥问题. 就丢给厂…

Ansys Zemax | 如何模拟自适应光学系统

概述 这篇文章介绍了如何在OpticStudio中使用多重结构创建反射式自适应光学系统。本文详细介绍了&#xff1a; 如何通过缩放光阑镜面的偏心来模拟一组镜面阵列 如何使用公差功能生成随机的波前差来模拟大气不均匀性对成像的影响 如何补偿该影响引入的像差以得到最优的几何和…

《TCP/IP网络编程》阅读笔记--基于TCP的服务器端/客户端

1--TCP/IP协议栈 TCP/IP协议栈共分 4 层&#xff0c;可以理解为数据收发分成了 4 个层次化过程&#xff1b; 链路层&#xff1a; 链路层是物理链接领域标准化的结果&#xff0c;专门定义LAN、WAN、MAN等网络标准&#xff1b; IP层&#xff1a; IP层用于解决数据传输过程中路径的…

第十八课、Qt 下载、安装与配置

功能描述&#xff1a;介绍了 Qt 的下载、安装和配置的全部过程&#xff0c;并对关键页面选项进行了详细说明 一、Qt 的下载 Qt 官方下载地址&#xff1a;https://www.qt.io/zh-cn/downloadhttps://download.qt.io/https://download.qt.io/https://www.qt.io/zh-cn/download进入…

Unity制作下雨中的地面效果

Unity引擎制作下雨效果 大家好&#xff0c;我是阿赵。   之前介绍了Unity引擎里面通过UV偏移做序列帧动画的做法&#xff0c;这里再介绍一个进阶的用法&#xff0c;模拟地面下雨的雨点效果。 一、原理 最基本的原理&#xff0c;还是基于这个序列帧动画的做法。不过这里做一点…

深度入门 Android 车机核心 CarService 的构成和链路

作者&#xff1a;TechMerger 本文将结合 Android 系统整体&#xff0c;对 CarService 的构成和链路对其做一个全面的分析和理解。 构成 1. CarServiceHelperService 系统服务 SystemServer 中专门为了 Automotive OS 设立的系统服务&#xff0c;用来管理车机的核心服务 CarS…

计算机网络的故事——了解Web及网络基础

了解Web及网络基础 文章目录 了解Web及网络基础一、使用 HTTP 协议访问 Web二、HTTP 的诞生三、网络基础 TCP/IP四、与 HTTP 关系密切的协议 : IP、TCP 和 DNS 一、使用 HTTP 协议访问 Web 根据Web浏览器指定的URL&#xff0c;从对应的服务器中获取文件资源&#xff0c;从而显…

LeetCode(力扣)77. 组合Python

LeetCode77. 组合 题目链接代码 题目链接 https://leetcode.cn/problems/combinations/description/ 代码 class Solution:def combine(self, n: int, k: int) -> List[List[int]]:result []return self.backtracking(n, k, 1, [], result)def backtracking(self, n, k…