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

晋江做任务的网站谷歌优化教程

晋江做任务的网站,谷歌优化教程,网站开发方案书,潜江资讯网招聘司机SQLite是一个轻量级的数据库解决方案,它是一个嵌入式的数据库管理系统。SQLite的特点是无需独立的服务器进程,可以直接嵌入到使用它的应用程序中。由于其配置简单、支持跨平台、服务器零管理,以及不需要复杂的设置和操作,SQLite非…

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的项目,谢谢!

http://www.dt0577.cn/news/5918.html

相关文章:

  • 做网站赚广告费多么徐州网站关键词排名
  • 公安网站备案公司做网络推广哪个网站好
  • 茂名快速建站模板网站建设优化推广系统
  • 网站建设需要的功能腾讯企点app
  • 国企网站建设方案360优化大师官方免费下载
  • 评网网站建设内容营销成功案例
  • 网站水印设置作教程网络营销模式有哪些类型
  • WordPress修改注册界面网站排名优化
  • 做海岛旅游预定网站的seo
  • 网站如何做中英文效果百度客服电话人工服务热线
  • 微信公众平台可以导入wordpressseo推广优化公司哪家好
  • 做网站是什么课武汉网站seo推广
  • 网站翻页模板十大免费b2b网站
  • 淄博学校网站建设报价体验营销案例
  • 寮步营销型网站建设石家庄seo代理商
  • wordpress点击弹出层插件建站优化推广
  • 怎么建设微信二维码发在网站上软件开发公司联系方式
  • 肯德基的网站建设整站优化要多少钱
  • whois哪个网站好网站备案查询
  • 深圳网站建设制作品牌公司四川最好的网络优化公司
  • 莱芜百度网站制作比百度好用的搜索引擎
  • 两个网站做的h5如何合在一起分销平台
  • 如何建设好幼儿园网站免费建网站哪家好
  • 聊城专业做网站的公司深圳网络推广的公司
  • 金猪云高端网站建设自动优化app
  • 网站建设个体营业执照营业推广的目标通常是
  • 书店网站建设百度资源平台链接提交
  • 如何用百度上传图片做网站外链seo网络培训学校
  • 国内做的好的网站谷歌引擎搜索
  • 建设官网流程百度推广优化排名