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)
sqlite3:分两种语言:
sqlite3应用程序的选项语言,一般以.开头
输入 .开头的命令(非sql语句命令)
.help:查看帮助
.tables :查看数据库有哪些表
.quit :退出sqlite
还有一种命令不是以
.开头的,这种叫sql语句,sql语句以
; 结束
总结:
sqlite3 以 . 开头的命令是 sqlite3命令
不是以 . 开头的是 sql语句,一定以
;结束
1.2数据库中的概念
数据库
将所有的数据,各种类型,描述各种事物的数据放到一起, 如:my.db文件,就是一个数据库文件
数据表
描述某一个事物的基本信息的表
学生信息表 (stu_info) 编号 姓名 性别 年龄 班级 爱好
图书信息表 (book_info) 图书编号 书名 出版社 作者 分类
记录
表里面的一条信息
字段
列名
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; //如果打开成功,将指向数据库的指针赋值给p
if(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的项目,谢谢!