当前位置: 首页 > news >正文

SQLite数据库在Linux系统上的使用

SQLite是一个轻量级的数据库解决方案,它是一个嵌入式的数据库管理系统。SQLite的特点是无需独立的服务器进程,可以直接嵌入到使用它的应用程序中。由于其配置简单、支持跨平台、服务器零管理,以及不需要复杂的设置和操作,SQLite非常适用于移动应用、小型项目和桌面应用程序。

1.安装数据库

可以在官网(http://www.sqlite.org/)下载安装包(我的安装包有点老就不给大家了)
libsqlite3-0_3.7.2-1ubuntu0.1_i386.deb (.deb的安装包可以用dpkg -i 来进行安装)
.deb 是linux 系统的应用程序的安装包文件
安装.deb文件: dpkg -i deb文件名 (dpkg -i :安装应用程序)

1.1 打开数据库

打开/新建数据库命令: sqlite3 my.db
(如果my.db 存在就打开,不存在就新建),创建成功后,当前目录会有一个my.db的文件
数据库 一般 扩展名是.db(database)
dd1d5acd8e8d45a4b40e9e2010af30c2.png
sqlite3:分两种语言:
sqlite3应用程序的选项语言,一般以.开头
输入 .开头的命令(非sql语句命令)
.help:查看帮助
.tables :查看数据库有哪些表
.quit :退出sqlite
还有一种命令不是以 .开头的,这种叫sql语句,sql语句以 ; 结束
总结:
sqlite3 以 . 开头的命令是 sqlite3命令
不是以 . 开头的是 sql语句,一定以 ;结束

1.2数据库中的概念

数据库
将所有的数据,各种类型,描述各种事物的数据放到一起, 如:my.db文件,就是一个数据库文件
数据表
描述某一个事物的基本信息的表
学生信息表 (stu_info)   编号 姓名 性别 年龄 班级 爱好
图书信息表 (book_info)   图书编号 书名 出版社 作者 分类
记录
表里面的一条信息
字段
列名
e181899118be420ebd45a1de6b43d8ba.png

2.sql语句(重点)

sql语句: 是一个标准的数据库语言,提供了对数据库操作的各种命令, 并且sql语句是所有数据库通用的。

2.1创建数据表

语句:create table stu_info (number varchar(20), name varchar(50), age integer, sex varchar(10));     //后面会用到这个表,大家了解一下
create table :关键字, 用来创建表
stu_info :自定义的表名
number name age sex :字段
varchar :可变字符串(数据类型) (默认50)
integer :整数数据类型

2.2 删除表

drop table +表名;     //执行前记得加分号

示例:drop table stu_info;  //删除stu_info表

2.3 插入记录到表中(重点)

1)字段全部添加的语句:insert into 表名 values(填入所有字段);   //注意结尾有分号

insert into stu_info values ('1001', 'zhangsan', 25, 'nan'); //所有字段全都填入值
2)只给某些字段添加值的语句:insert into stu_info (age,number) values (26, '1002');   //age,number是不添加值的字段。

2.4查询表中的记录(重点)

select * from stu_info; //   * 是查看stu_info表里的所有字段
select age from stu_info; //查看age字段
select age,number from stu_info; //查看多个字段间用逗号隔开
sql命令:
.header on :显示字段名
.mode column :列对齐

按一个条件查询

select * from stu_info where name = 'lisi';  //查询表里name='lisi'的记录

按多个条件查询

select * from stu_info where name = 'lisi' and age = 25;   
select * from stu_info where name = 'lisi' or age = 25;

其他各种查询

1 查询年龄 > 25的记录
select * from stu_info where age > 25;
2 查询记录 只想看编号、姓名字段
select number, age from stu_info where age = 25;    //查询age=25的记录,只看number,age字段
3 按顺序输出所有记录
select * from stu_info order by age; //按年龄顺序输出,默认情况是升序排列
select * from stu_info order by age desc; //降序排列
4 模糊查询(假设有一个人名我记不住了,但能记住名字中的一个字, 就可以用模糊查询)
示例:查询名字当中带li字符的人(like)
select * from stu_info where name like '%li%';  // % 代替后续或者前面的内容
5 多条件查询
select * from stu_info where age > 25 and number > 1001; //(查询年龄大于 25, 编号 > 1001 的学生信息)
6 统计记录条数
select count(*) from stu_info;
select count(*) from stu_info where age = 25;
练习:
1. 创建学生成绩表(字段如下)
学生编号(number) 数学(math) 语文(ch) 英语(en)
2. 向学生成绩中添加三条记录
1001 100 90 80
1002 80 90 80
1003 90 90 80
3. 查询出编号1003的记录
create table score_info (number varchar(20), math integer, ch integer, en
integer);insert into score_info values ('1001', 100, 90, 80); //所有字段全都填入值
insert into score_info values ('1002', 80, 90, 80); //所有字段全都填入值
insert into score_info values ('1003', 90, 90, 80); //所有字段全都填入值select * from score_info where number = '1003';

2.5 删除表中记录(重点)

示例: delete from stu_info; //删除所有记录
delete from stu_info where number = '1002'; //删除number = '1002的记录

2.6修改表中记录(重点)

示例:把字段number为1004 的记录,该记录中name改成wangwu

update stu_info set name = 'wangwu' where number = '1004';

2.7多表联合查询

学生基本信息表:
number name age sex
成绩表:
nubmer math ch en
两个表number字段相同
示例:查询数学成绩 > 90的所有学生的基本信息和成绩
select stu_info.*, score_info.math from stu_info, score_info where score_info.math > 90 and stu_info.number = score_info.number;     //显示的字段有score_info1的math字段,还有stu_info整个表的字段   (必须有一个字段是相同的)

3.c语言操作数据库

3.1 打开数据库

头文件:#include <sqlite3.h>
函数: int sqlite3_open(char *path, sqlite3 **db);
功能: 打开数据库,如果数据不存在,则新建
参数:
path [入参] :打开的数据库名称(路径)
db [出参] :打开数据库后,它将指向数据库的指针给db
返回值:
执行成功返回SQLITE_OK(0),否则返回其他值
例如:
sqlite3* db;//FILE* fp
sqlite3_open("my.db", &db);
#include <stdio.h>
#include <sqlite3.h>
int main()
{sqlite3 *p; //如果打开成功,将指向数据库的指针赋值给pif(sqlite3_open("my.db", &p) == 0) //如果数据库不存在,就创建{printf("database open success\n");sqlite3_close(p);}
}

编译:gcc test.c -lsqlite3

3.2 执行数据库操作的sql语句

(只用于insert into, create table, update, delete)

int sqlite3_exec(sqlite3 *db, const char *sql, sqlite3_callback callback,
void *, char **errmsg);
参数 
db , sqlite3_open 的第二个参数
sql, 要执行的sql语句
NULL 默认为NULL (非NULL值用在查询中)
NULL 默认为NULL
errmsg: [出参] 如果sql语句执行错误,errmsg中保存错误字符串
返回值:成功返回0,不成功返回其他
#include <stdio.h>
#include <sqlite3.h>
int main()
{sqlite3 *p;if(sqlite3_open("my.db", &p) == 0) //如果数据库不存在,就创建{printf("database open success\n");if(sqlite3_exec(p, "delete from stu_info where name = 'zhangsan'", NULL,NULL, NULL) == 0){printf("delete success\n");}}
}

3.3查询语句

函数: int sqlite3_get_table(sqlite3 *db, const char *sql, char ***resultp, int*nrow, int *ncolumn, char **errmsg);
功能:执行SQL查询操作。
参数:
db:指向数据库指针(数据库句柄), open的第二个参数
sql:SQL语句, (select * from stu_info)
resultp[出参]:用来指向sql执行结果的指针 (跟errmsg类似)
nrow[出参]:满足条件的记录的数目, 包括字段名,相当于行数(表头会返回出来,但表头不计入行 数,所以打印时需要打印nrow+1行)
ncolumn[出参]:每条记录包含的字段数目,相当于列数

errmsg:错误信息指针的地址, 如果语句执行出错,那么errmsg中是错误信息 返回值:成功返回0,失败返回错误码

示例:

#include <stdio.h>
#include <sqlite3.h>
#include <stdlib.h>
int main()
{sqlite3 *db;char *errmsg;char **q;int nrow, ncolumn, i, j, index = 0;if(sqlite3_open("my.db", &db) == 0){if(sqlite3_get_table(db, "select * from stu_info", &q, &nrow,&ncolumn, &errmsg) != 0){printf("error : %s\n", errmsg);exit(-1);}else{for (i=0; i < nrow + 1; i++) //nrow 是行, 如果有1条记录,那么值为1{for (j=0; j<ncolumn; j++){printf("%10s", q[index++]); //printf("%10s",q[i*ncolumn + j]);}printf("\n");}}}
}

4.结语

这就是sqlite数据库在Linux上使用教程,感谢大家的观看,希望大家点点赞,点点关注,后续会出用到sqlite的项目,谢谢!

相关文章:

SQLite数据库在Linux系统上的使用

SQLite是一个轻量级的数据库解决方案&#xff0c;它是一个嵌入式的数据库管理系统。SQLite的特点是无需独立的服务器进程&#xff0c;可以直接嵌入到使用它的应用程序中。由于其配置简单、支持跨平台、服务器零管理&#xff0c;以及不需要复杂的设置和操作&#xff0c;SQLite非…...

Spring中依赖注入的方法有几种,分别是什么?

依赖注入的目的&#xff1a; 都是为了减少对象之间的紧密耦合 1. 构造函数注入&#xff1a;通过在类的构造函数中接受依赖对象作为参数&#xff0c;Spring在创建对象时将依赖注入。 2. Setter方法注入&#xff1a;在类中提供setter方法&#xff0c;Spring通过调用这些setter方法…...

【面试精讲】MyBatis设计模式及源码分析,MyBatis设计模式实现原理

【面试精讲】MyBatis设计模式及源码分析&#xff0c;MyBatis设计模式实现原理 目录 本文导读 一、MyBatis中运用的设计模式详解 1. 工厂模式&#xff08;Factory Pattern&#xff09; 2. 单例模式&#xff08;Singleton Pattern&#xff09; 3. 建造者模式&#xff08;Bu…...

Acrel-1000DP光伏监控系统在尚雷仕(湖北)健康科技有限公司5.98MW分布式光伏10KV并网系统的应用

摘 要&#xff1a;分布式光伏发电特指在用户场地附近建设&#xff0c;运行方式多为自发自用&#xff0c;余电上网&#xff0c;部分项目采用全额上网模式。分布式光伏全额上网的优点是可以充分利用分布式光伏发电系统的发电量&#xff0c;提高分布式光伏发电系统的利用率。发展分…...

电脑远程控制esp32上的LED

1、思路整理 首先esp32需要连接上wifi 然后创建udp socket 接受udp数据 最后解析数据&#xff0c;控制LED 2、micropython代码实现 import network from socket import * from machine import Pin p2Pin(2,Pin.OUT)def do_connect(): #连接wifi wlan network.WLAN(network.…...

ARXML处理 - C#的解析代码(一)

目的 本文介绍通过AUTOSAR组织提供的xsd文件&#xff0c;自动生成对应的C#解析代码的框架。 自动生成方法&#xff1a;Microsoft SDKs\Windows\v7.0A\bin\xsd.exe 命令&#xff1a;xsd.exe AUTOSAR_4-0-3.xsd /c /l:CS /n:AUTOSAR4 AUTOSAR_4-0-3.xsd 是需要生成代码的xsd文…...

OJ 栓奶牛【C】【Python】【二分算法】

题目 算法思路 要求的距离在最近木桩与最远木桩相隔距离到零之间&#xff0c;所以是二分法 先取一个中间值&#xff0c;看按照这个中间值可以栓多少奶牛&#xff0c;再与输入奶牛数比较&#xff0c;如果大于等于&#xff0c;则增大距离&#xff0c;注意这里等于也是增大距离…...

Spring6-单元测试:JUnit

1. 概念 在进行单元测试时&#xff0c;特别是针对使用了Spring框架的应用程序&#xff0c;我们通常需要与Spring容器交互以获取被测试对象及其依赖。传统做法是在每个测试方法中手动创建Spring容器并从中获取所需的Bean。以下面的两行常见代码为例&#xff1a; ApplicationCo…...

ubuntu系统安装k8s1.28精简步骤

目录 一、规划二、环境准备2.1 配置apt仓库配置系统基本软件仓库配置k8s软件仓库安装常用软件包 2.2 修改静态ip、ntp时间同步、主机名、hosts文件、主机免密2.3 内核配置2.4 关闭防火墙、selinux、swap2.5 安装软件安装docker安装containerd安装k8s软件包 三、安装配置k8s3.1 …...

探讨Java和Go语言的缺点

文章目录 Java的缺点Go语言的缺点 通常我们都会讨论Java和GO的优点&#xff0c;如果讨论缺点往往能让人们更清楚优点的重要性&#xff0c;Java和Go的缺点或许往往就是对方优点所在 Java的缺点 冗长的代码&#xff1a;相较于一些现代编程语言&#xff0c;Java 的语法相对冗长&am…...

短剧在线搜索PHP网站源码

源码简介 短剧在线搜索PHP网站源码&#xff0c;自带本地数据库500数据&#xff0c;共有6000短剧视频&#xff0c;与短剧猫一样。 搭建环境 PHP 7.3 Mysql 5.6 安装教程 1.上传源码到网站目录中 2.修改【admin.php】中&#xff0c; $username ‘后台登录账号’; $passwor…...

Python map遍历

在Python中&#xff0c;map 函数是一个内置函数&#xff0c;它将指定的函数应用于给定序列&#xff08;如列表、元组等&#xff09;的每个项&#xff0c;并返回一个迭代器&#xff0c;该迭代器包含所有项经过指定函数处理后的结果。 ### map 函数的基本用法 map 函数的语法如…...

数据结构—红黑树

红黑树介绍 红黑树&#xff08;Red Black Tree&#xff09;是一种自平衡二叉查找树。由于其自平衡的特性&#xff0c;保证了最坏情形下在 O(logn) 时间复杂度内完成查找、增加、删除等操作&#xff0c;性能表现稳定。 在 JDK 中&#xff0c;TreeMap、TreeSet 以及 JDK1.8 的 …...

MES实施之工控机和电脑的选择

在MES项目实施过程中,经常会碰到工控机和电脑的选型问题,那么他们的区别是什么? 1、控机和普通个人电脑(PC)相比,具有以下几个区别: 1.运行环境不同:工控机通常需要在各种恶劣的工业环境中运行,如高温、高湿、强电磁干扰等,因此需要具有防尘、防水、抗干扰等特点。而…...

京东云服务器4核8G主机租用价格418元一年,1899元3年

京东云轻量云主机4核8G服务器租用价格418元一年&#xff0c;1899元3年&#xff0c;配置为&#xff1a;轻量云主机4C8G-180G SSD系统盘-5M带宽-500G月流量&#xff0c;京东云主机优惠活动 yunfuwuqiba.com/go/jd 可以查看京东云服务器详细配置和精准报价单&#xff0c;活动打开如…...

【多模态融合】MetaBEV 解决传感器故障 3D检测、BEV分割任务

前言 本文介绍多模态融合中&#xff0c;如何解决传感器故障问题&#xff1b;基于激光雷达和相机&#xff0c;融合为BEV特征&#xff0c;实现3D检测和BEV分割&#xff0c;提高系统容错性和稳定性。 会讲解论文整体思路、模型框架、论文核心点、损失函数、实验与测试效果等。 …...

[通俗易懂]《动手学强化学习》学习笔记1-第1章 初探强化学习

文章目录 前言第1章 初探强化学习1.1 简介序贯决策&#xff08;sequential decision making&#xff09;任务&#xff1a;强化学习与有监督学习或无监督学习的**区别**&#xff1a;改变未来 1.2 什么是强化学习环境交互与有监督学习的区别1&#xff1a;改变环境 &#xff08;说…...

centOS如何升级python

centOS下升级python版本的详细步骤 1、可利用linux自带下载工具wget下载&#xff0c;如下所示&#xff1a; 笔者安装的是最小centos系统&#xff0c;所以使用编译命令前&#xff0c;必须安装wget服务&#xff0c;读者如果安装的是界面centos系统&#xff0c;或者使用过编译工具…...

【MYSQL锁】透彻地理解MYSQL锁

&#x1f525;作者主页&#xff1a;小林同学的学习笔录 &#x1f525;mysql专栏&#xff1a;小林同学的专栏 目录 1.锁 1.1 概述 1.2 全局锁 1.2.1 语法 1.2.1.1 加全局锁 1.2.1.2 数据备份 1.2.1.3 释放锁 1.2.1.4 特点 1.2.1.5 演示 1.3 表级锁 1.3.1 介绍 …...

【静态分析】静态分析笔记01 - Introduction

参考&#xff1a; BV1zE411s77Z [南京大学]-[软件分析]课程学习笔记(一)-introduction_南京大学软件分析笔记-CSDN博客 ------------------------------------------------------------------------------------------------------ 1. program language and static analysis…...

使用的sql

根据CODE去重 SELECT * FROM ( SELECT count( camera_code ) AS count, camera_code FROM n_camera_basic GROUP BY camera_code ) t WHERE t.count >1 DELETE FROM n_camera_basic WHERE camera_id NOT IN (SELECT dt.minno…...

【ZZULIOJ】1052: 数列求和4(Java)

目录 题目描述 输入 输出 样例输入 Copy 样例输出 Copy code 题目描述 输入n和a&#xff0c;求aaaaaa…aa…a(n个a)&#xff0c;如当n3,a2时&#xff0c;222222的结果为246 输入 包含两个整数&#xff0c;n和a,含义如上述&#xff0c;你可以假定n和a都是小于10的非负整…...

【Linux】tcpdump P3 - 过滤和组织返回信息

文章目录 基于TCP标志的过滤器格式化 -X/-A额外的详细选项按协议(udp/tcp)过滤低详细输出 -q时间戳选项 本文继续展示帮助你过滤和组织tcpdump返回信息的功能。 基于TCP标志的过滤器 可以根据各种TCP标志来过滤TCP流量。这里是一个基于tcp-ack标志进行过滤的例子。 # tcpdump…...

vscode免费登录ssh ,linux git配置免密码

1、vscode远程ssh免密 在windows下生成密钥 , cmd窗口下执行 ssh-keygen -t rsa 在C:\Users\xxxx\.ssh目录下生成 在linux下面 cd .ssh 创建authorized_keys 文件&#xff0c; 把之前windows下生成的 id_rsa.pub内容复制进去 2、gitlab 配置。 在linux下面 ssh-keygen -t rs…...

Netty 心跳(heartbeat)——服务源码剖析(上)(四十一)

剖析目的 Netty 作为一个网络框架&#xff0c;提供了诸多功能&#xff0c;比如编码解码等&#xff0c;Netty 还提供了非常重要的一个服务----心跳机制 heartbeat.通过心跳检査对方是否有效,这是 RPC 框架中是必不可少的功能。下面我们分析一下 Netty 内部心跳服务源码实现。 源…...

C语言—每日选择题—Day65

前言 我们的刷题专栏又又又开始了&#xff0c;本专栏总结了作者做题过程中的好题和易错题。每道题都会有相应解析和配图&#xff0c;一方面可以使作者加深理解&#xff0c;一方面可以给大家提供思路&#xff0c;希望大家多多支持哦&#xff5e; 第一题 1、如下代码输出的是什么…...

【环境变量】基本概念理解 | 查看环境变量echo | PATH的应用和修改

目录 前言 基本概念&理解 注意的点 查看环境变量的方法 PATH环境变量 PTAH应用系统指令 PTAH应用用户程序 命令行参数的修改&#xff08;内存级&#xff09; 配置文件的修改 windows环境变量 大家天天开心&#x1f642; bash进程的流程。环境变量在系统指…...

5.7Python之元组

元组&#xff08;Tuple&#xff09;是Python中的一种数据类型&#xff0c;它是一个有序的、不可变的序列。元组使用圆括号 () 来表示&#xff0c;其中的元素可以是任意类型&#xff0c;并且可以包含重复的元素。 与列表&#xff08;List&#xff09;不同&#xff0c;元组是不可…...

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单视频处理实战案例 之一 简单视频放大抖动效果

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单视频处理实战案例 之一 简单视频放大抖动效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单视频处理实战案例 之一 简单视频放大抖动效果 一、简单介绍 二、简单视频放大抖动效果实现原理 三、简单视频放大…...

如何通过VPN访问内网?

VPN&#xff08;Virtual Private Network&#xff09;是一种通过公共网络建立私有网络连接的技术&#xff0c;可以在不同地点的网络中建立安全通道&#xff0c;实现远程访问内网资源的目的。本文将介绍如何通过VPN访问内网&#xff0c;并介绍一款名为“天联”的VPN服务。 什么是…...