嵌入式数据库sqlite3「基础篇」基本命令操作小白一看就懂
liebian365 2024-11-19 06:26 3 浏览 0 评论
前言
数据在实际工作中应用非常广泛,数据库的产品也比较多,oracle、DB2、SQL2000、mySQL;基于嵌入式linux的数据库主要有SQLite, Firebird, Berkeley DB, eXtremeDB。
本文主要讲解数据库SQLite,通过这个开源的小型的嵌入式数据库带领大家掌握一些基本的数据库操作,这些操作在很多系统中都是通用的,可谓学一通百。
SQLite
SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。
作者D.RichardHipp
2000年1月,Hipp开始和一个同事讨论关于创建一个简单的嵌入式SQL数据库的想法,这个数据库将使用GNU DBM哈希库(gdbm)做后台,同时这个数据库将不需要安装和管理支持。后来,一有空闲时间,Hipp就开始实施这项工作,2000年8月,SQLite 1.0版发布了。【在此向大神献上我的膝盖!】
它的设计目标是嵌入式的,而且已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源的世界著名数据库管理系统来讲,它的处理速度比他们都快。
SQLite特性
- 零配置一无需安装和管理配置;
- 储存在单一磁盘文件中的一个完整的数据库;
- 数据库文件可以在不同字节顺序的机器间自由共享;
- 支持数据库大小至2TB;
- 足够小,全部源码大致3万行c代码,250KB;
- 比目前流行的大多数数据库对数据的操作要快。
安装
现在运行的主要是sqlite3版本,在ubuntu下安装也非常方便。
sudo apt-get install sqlite sqlite3 安装应用程序
sudo apt-get install libsqlite3-dev 安装库+头文件,用代码操作数据库必须安装
查看版本号: 输入命令 sqlite3进入操作界面,输入命令.version,即可查看详细版本号。
也可以使用下面命令,安装图形化操作工具:
sudo apt-get install sqlitebrowser 图形化工具建立数据库
除此之外,还可以部署在windows下,本文只讨论ubtuntu下,采用命令行方式来操作数据库。
数据类型
操作数据库,主要就是操作表,表的每一列内容都有一定数据类型,比如整型值、字符串、布尔型等。
Sqlite3主要数据类型如下:
数据类型 定义 数据类型 NULL 表示该值为NULL值。 INTEGER 无符号整型值。 REAL 浮点值。 TEXT 文本字符串,存储使用的编码方式为UTF-8、UTF-16BE、UTF-16LE。 BLOB 存储Blob数据,该类型数据和输入数据完全相同,1表示true,0表示false。
同时sqlite3也接受如下的数据类型:
数据类型 定义 smallint 16位的整数。 interger 32位的整数。 decimal(p,s) 精确值p是指全部有几个十进制数,s是指小数点后可以有几位小数。如果没有特别指定,则系统会默认为p=5 s=0 。 float 32位元的实数。 double 64位元的实数。 char(n) n 长度的字串,n不能超过 254。 varchar(n) 长度不固定且其最大长度为 n 的字串,n不能超过 4000。 graphic(n) 和 char(n) 一样,不过其单位是两个字节, n不能超过127。这个形态是为了支持两个字节长度的字体,如中文字。 vargraphic(n) 可变长度且其最大长度为n的双字元字串,n不能超过2000 date 包含了 年份、月份、日期。 time 包含了 小时、分钟、秒。 timestamp 包含了 年、月、日、时、分、秒、千分之一秒。
约束
表的每一列都有一些限制属性,比如有的列的数据不能重复,有的则限制数据范围等,约束就是用来进一步描述每一列数据属性的。 SQLite 数据库常用约束如下:
名称 定义 NOT NULL - 非空 UNIQUE 唯一 PRIMARY KEY 主键 FOREIGN KEY 外键 CHECK 条件检查 DEFAULT 默认
非空 NOT NULL
有一些字段我们可能一时不知到该填些什么,同时它也没设定默认值, 当添加数据时,我们把这样的字段空着不填,系统认为他是 NULL 值。但是还有另外一类字段,必须被填上数据,如果不填,系统就会报错。 这样的字段被称为 NOT NULL 非空字段,需要在定义表的时候事先声明。
唯一 UNIQUE
除了主列以为,还有一些列也不能有重复值。
主键 PRIMARY KEY
一般是整数或者字符串,只要保证唯一就行。 在 SQLite 中,主键如果是整数类型,该列的值可以自动增长。
外键 FOREIGN KEY
我们的数据库中已经有 Teachers 表了,假如我们再建立一个 Students 表, 要求 Students 表中的每一个学生都对应一个 Teachers 表中的教师。 很简单,只需要在 Students 表中建立一个 TeacherId 字段,保存对应教师的 Id 号, 这样,学生和教师之间就建立了关系。 问题是:我们有可能给学生存入一个不在 Teachers 表中的 TeacherId 值, 而且发现不了这个错误。 这种情况下,可以把 Students 表中 TeacherId 字段声明为一个外键, 让它的值对应到 Teachers 表中的 Id 字段上。 这样,一旦在 Students 表中存入一个不存在的教师 Id ,系统就会报错。
默认值 DEFAULT
有一些特别的字段列,在每一条记录中,他的值基本上都是一样的。只是在个别情况下才改为别的值,这样的字段列我们可以给他设一个默认值。
条件检查 CHECK
某些值必须符合一定的条件才允许存入,这是就需要用到这个 CHECK 约束。
常用命令
下面介绍Shell模式中的各常用命令的使用。
命令 功能 .help 可显示shell模式中可使用的所有命令列表 .database 显示数据库信息;包含当前数据库的位置 .mode column 使得SQL语句处理的结果以列对齐的方式显示 .mode list column .headers on/off 打开关闭列标题显示开关,以使得查询结果在屏幕显示时具有列标题 .tables 列出当前打开的数据库中共有多少张表 .exit 退出SQLite环境 .schema foods 显示表foods 创建时的SQL语句 .schema 显示所有表被创建时的语句 .nullvalue STRING 查询时用指定的串代替输出的NULL串 默认为.nullvalue '' .show 显示shell模式中定义的与输出相关的一些设置 .output file.csv 设置输出文件格式为CSV,文件名为file.csv .separator , 设置select语句输出的列数据间以“ ,”分隔 .output stdout 恢复输出内容到标准输出设备(屏幕)
【注意】sqlite的命令都是.开头的,操作语句前面是没有.的。
使用实例
数据库的操作语句主要是增删改查,下面我们通过一些实例让大家了解数据库的这些基本操作。
表类型
假设我们要创建一个教学管理的数据库jxgl.db,数据库中要保存学生表STUDENT。
sno sname ssex sage sdept 95001 yikou m 21 cs 95002 peng m 21 cs
根据我们的常识,可知每一列的数据有以下特性:
- sno 学号:整型值,每个人学号是唯一的,学校一般用学号来区分所有的学生,而且一般学号是递增的,所以我们设置sno为primary key;
- sname 姓名:一般是字符串,可以重复,但是不能为空;
- ssex 性别:字符串,可以为空;
- sage 年龄:整型值,假定年龄要大于14;
- sdept 专业:字符串,可以为空,此处我们默认为'CS'。
下面我们一步步实现这个数据库的所有操作。
创建教学管理“jxgl”数据库
数据库的打开和退出,使用如下命令。
创建表:
CREATE TABLE IF NOT EXISTS STUDENT(Sno integer primary key, Sname text not null, Ssex text,Sage integer check(Sage>14),Sdept text default 'CS');
该表的属性就是按照上一节表属性 执行结果:
查看表:
看到STUDENT,说明该表创建好了。 【注意】
- 操作语句不是命令,前面不要加. ;
- 操作语句后面一定要;结尾,如果漏掉了,一定要补上分号;
- 操作语句对字母的全角半角很敏感,所有的符号都要用半角。
插入数据
插入数据采用insert into语句来实现,如下所示:
INSERT INTO STUDENT VALUES('95001','李勇','M',20,'CS');
INSERT INTO STUDENT VALUES('95002','刘晨','F',19,'IS');
INSERT INTO STUDENT VALUES('95003','王敏','F',18,'MA');
INSERT INTO STUDENT VALUES('95004','张立','M',18,'IS');
执行结果如下:
在这里插入图片描述
插入的数据只初始化部分值
设置了not null那一列 必须要赋值,而且表名字不区分大小写。
insert into student(sname,sage) values ('一口',19);
在这里插入图片描述
查看表
用SELECT语句查看表中的内容:
SELECT * FROM STUDENT;
其中的 * 表示查看所有的数据信息。
有没有看到,结果看起来不舒服啊,下面我们来调整下显示格式:
sqlite> .headers on 显示列名
sqlite> .mode column 列对齐
在这里插入图片描述
删除一行信息
delete from student where sname='一口';
由上图可见,名字为“一口”的那条记录被删除了。
修改一条记录的某个内容
UPDATE student SET sage=29 WHERE sname='张立';
在这里插入图片描述
修改数据表结构。
修改表结构,需要用到语句ALTER TABLE。 下面我们向STUDENT表增加“spwd”列,其数据类型为TEXT型,用SELECT命令查看表中内容。
ALTER TABLE STUDENT ADD spwd TEXT default '123456';
在这里插入图片描述
修改表名字
alter table student rename to stu;
在这里插入图片描述
删除数据表。
DROP TABLE STUDENT;
删除列
sqlite3没有实现删除一列的命令,要实现这个操作,需要先将该表拷贝到一个新表,但是只集成需要的列,要删除的列不继承过来。 可以 用以下方式操作删除一列:
sqlite> create table test as select sno, sname,ssex,sage,sdept from stu;
sqlite> drop table stu;
sqlite> alter table test rename to stu;
由上图可知,我们刚才增加的列spwd被删除了。
sqlite进阶
where子句
如果我不想查看所有的数据,而指向查看某一个人的信息要怎么操作呢? 我们就要借助where子句来实现。 where子句可以结合操作语句来进程增删改查,是最常用的一个子句。
根据姓名查找记录:
Select * from student where sname='一口';
根据学号查找记录:
Select * from student where sno=95001;
根据姓名和年龄同时查找记录:
select *from student where sname='一口' and sage=19;
显示某两列的数据
select sno,sname from student ;
在这里插入图片描述
数据库的备份和恢复
现在我们假设要将表foods备份出为foodsdb.sql,并用命令回复该数据库。 按照以下步骤操作即可。
sqlite>.dump --把创建表及向表中插入记录的所有SQL语句显示在屏幕上
sqlite>.output foodsdb.sql --指定dump命令输出到文件的文件名
sqlite>.dump --输出创建并插入数据到基本表的SQL语句到output指定的文件
sqlite>.output stdout --恢复输出内容到标准输出设备(屏幕)
sqlite>.dump --此时输出的SQL语句转回到屏幕
sqlite>Drop table foods; --删除foods表语句说明:
上述Drop为SQL语句,用于删除指定的表。因为是SQL语句,因此以“;”结尾
sqlite>.read foodsdb.sql --执行foodsdb.sql中的包含的所有SQL语句,用来重建刚删除的4张表及相关数据
好了,跟着一口君一步步操作,基本上sqlite3的增删改查操作,相信各位应该没什么问题了,sqlite还有其他一些子句以及函数的用法,留待下一篇继续介绍。
获取更多关于Linux的资料,请关注公众号「一口Linux」
相关推荐
- 快递查询教程,批量查询物流,一键管理快递
-
作为商家,每天需要查询许许多多的快递单号,面对不同的快递公司,有没有简单一点的物流查询方法呢?小编的回答当然是有的,下面随小编一起来试试这个新技巧。需要哪些工具?安装一个快递批量查询高手快递单号怎么快...
- 一键自动查询所有快递的物流信息 支持圆通、韵达等多家快递
-
对于各位商家来说拥有一个好的快递软件,能够有效的提高自己的工作效率,在管理快递单号的时候都需要对单号进行表格整理,那怎么样能够快速的查询所有单号信息,并自动生成表格呢?1、其实方法很简单,我们不需要一...
- 快递查询单号查询,怎么查物流到哪了
-
输入单号怎么查快递到哪里去了呢?今天小编给大家分享一个新的技巧,它支持多家快递,一次能查询多个单号物流,还可对查询到的物流进行分析、筛选以及导出,下面一起来试试。需要哪些工具?安装一个快递批量查询高手...
- 3分钟查询物流,教你一键批量查询全部物流信息
-
很多朋友在问,如何在短时间内把单号的物流信息查询出来,查询完成后筛选已签收件、筛选未签收件,今天小编就分享一款物流查询神器,感兴趣的朋友接着往下看。第一步,运行【快递批量查询高手】在主界面中点击【添...
- 快递单号查询,一次性查询全部物流信息
-
现在各种快递的查询方式,各有各的好,各有各的劣,总的来说,还是有比较方便的。今天小编就给大家分享一个新的技巧,支持多家快递,一次能查询多个单号的物流,还能对查询到的物流进行分析、筛选以及导出,下面一起...
- 快递查询工具,批量查询多个快递快递单号的物流状态、签收时间
-
最近有朋友在问,怎么快速查询单号的物流信息呢?除了官网,还有没有更简单的方法呢?小编的回答当然是有的,下面一起来看看。需要哪些工具?安装一个快递批量查询高手多个京东的快递单号怎么快速查询?进入快递批量...
- 快递查询软件,自动识别查询快递单号查询方法
-
当你拥有多个快递单号的时候,该如何快速查询物流信息?比如单号没有快递公司时,又该如何自动识别再去查询呢?不知道如何操作的宝贝们,下面随小编一起来试试。需要哪些工具?安装一个快递批量查询高手快递单号若干...
- 教你怎样查询快递查询单号并保存物流信息
-
商家发货,快递揽收后,一般会直接手动复制到官网上一个个查询物流,那么久而久之,就会觉得查询变得特别繁琐,今天小编给大家分享一个新的技巧,下面一起来试试。教程之前,我们来预览一下用快递批量查询高手...
- 简单几步骤查询所有快递物流信息
-
在高峰期订单量大的时候,可能需要一双手当十双手去查询快递物流,但是由于逐一去查询,效率极低,追踪困难。那么今天小编给大家分享一个新的技巧,一次能查询多个快递单号的物流,下面一起来学习一下,希望能给大家...
- 物流单号查询,如何查询快递信息,按最后更新时间搜索需要的单号
-
最近有很多朋友在问,如何通过快递单号查询物流信息,并按最后更新时间搜索出需要的单号呢?下面随小编一起来试试吧。需要哪些工具?安装一个快递批量查询高手快递单号若干怎么快速查询?运行【快递批量查询高手】...
- 连续保存新单号功能解析,导入单号查询并自动识别批量查快递信息
-
快递查询已经成为我们日常生活中不可或缺的一部分。然而,面对海量的快递单号,如何高效、准确地查询每一个快递的物流信息,成为了许多人头疼的问题。幸运的是,随着科技的进步,一款名为“快递批量查询高手”的软件...
- 快递查询教程,快递单号查询,筛选更新量为1的单号
-
最近有很多朋友在问,怎么快速查询快递单号的物流,并筛选出更新量为1的单号呢?今天小编给大家分享一个新方法,一起来试试吧。需要哪些工具?安装一个快递批量查询高手多个快递单号怎么快速查询?运行【快递批量查...
- 掌握批量查询快递动态的技巧,一键查找无信息记录的两种方法解析
-
在快节奏的商业环境中,高效的物流查询是确保业务顺畅运行的关键。作为快递查询达人,我深知时间的宝贵,因此,今天我将向大家介绍一款强大的工具——快递批量查询高手软件。这款软件能够帮助你批量查询快递动态,一...
- 从复杂到简单的单号查询,一键清除单号中的符号并批量查快递信息
-
在繁忙的商务与日常生活中,快递查询已成为不可或缺的一环。然而,面对海量的单号,逐一查询不仅耗时费力,还容易出错。现在,有了快递批量查询高手软件,一切变得简单明了。只需一键,即可搞定单号查询,一键处理单...
- 物流单号查询,在哪里查询快递
-
如果在快递单号多的情况,你还在一个个复制粘贴到官网上手动查询,是一件非常麻烦的事情。于是乎今天小编给大家分享一个新的技巧,下面一起来试试。需要哪些工具?安装一个快递批量查询高手快递单号怎么快速查询?...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- wireshark怎么抓包 (75)
- qt sleep (64)
- cs1.6指令代码大全 (55)
- factory-method (60)
- sqlite3_bind_blob (52)
- hibernate update (63)
- c++ base64 (70)
- nc 命令 (52)
- wm_close (51)
- epollin (51)
- sqlca.sqlcode (57)
- lua ipairs (60)
- tv_usec (64)
- 命令行进入文件夹 (53)
- postgresql array (57)
- statfs函数 (57)
- .project文件 (54)
- lua require (56)
- for_each (67)
- c#工厂模式 (57)
- wxsqlite3 (66)
- dmesg -c (58)
- fopen参数 (53)
- tar -zxvf -c (55)
- 速递查询 (52)