Linux下数据库(sqlite3)学习笔记

                                                                       sqlite3 数据库安装

1. 本地安装

sudo dpkg -i *.deb

2.在线安装

sudo apt-get install sqlite3

3.使用压缩包解压

压缩包下载路径:链接:https://pan.baidu.com/s/1xHLZGObQODUGBReNEi3KKQ
提取码:zjqv

 

                                                                       SQLITE3 基本命令

 

两种命令

1.以 . 开头的称之为系统命令

.help 帮助

.quit 退出

.exit 退出

.databases 查看打开的数据库(显示数据库的名字和路径)

.table 查看当前数据库的表格

 

2. 以 , 结尾的 sql命令

创建一张数据库表 stu :

creat table stu(Id Integer, name char, score Integer );

 

查看表的结构图:

.schema

 

在数据表中插入数据(完全插入 所有参数必须都有)

insert into +数据表名 values(相应数据)

 

在数据表中插入数据(部分插入 部分参数就行)

insert into +数据表名((参数名一,。。。。。, 参数名N)values(参数值一, 。。。。,参数值N))

 

查看数据表中的内容(查询全部内容)

select * from +数据表名

 

查询数据表中的内容 (查询部分内容)

select name, sroce from +数据表名

 

查询数据表内容 (查询特定内容)

select * from +数据表名 where 参数=?;(一个限定条件)

select * from +数据表名 where 参数1=? and 参数2=?;(两个限定条件必须同时满足)

select * from +数据表名 where 参数1=? or 参数2=?;(两个限定条件满足一个就行)

删数据表中的内容

delete frm +数据表名 ;(删除整个数据表)

delete from +数据表名 where 参数=?;(删除特定内容)

其他和查询内容都一样 依然可以使用and 和or

 

设置数据表中的内容

update +数据表名 set 参数1=?where 参数2=?;

update +数据表名 set 参数1=?, 参数2=?where 参数3=? ;

 

删除数据表

drop table 数据表名

 

给数据表重命名

alter table +原的数据表名 rename to 要改成的数据表名

给数据库添加一列统计信息

alter table +数据表名 add column 要添加的统计信息 要添加的信息的类型;

 

sqlite不支持删除一列信息

所以只能间接删除 步骤如下:

1.创建一张新表

2.删除原有的表

3.将新表的名字改成原来的表的名字

这样旧表的内容会自动写入到新表中

 

 

                                                          API()

 

头文件:#include <stdlib.h>

编译指令·: gcc 文件名.c -lsqlite3

 

int sqlite3_open(const char *filename, sqlite3 **ppDb);

作用:打开一个数据库

参数:filename 数据库路径

ppDb 代表数据库的操作句柄(指针)

返回值: 成功返回 SQLITE_OK 失败返回错误码

 

int sqlite3_close(sqlite3 *db);

作用:关闭数据库

参数: db操作数据库的指针

返回值:成功返回SQLITE_OK 失败返回错误码

 

const char *sqlite3_errmsg(sqlite3 *db)

功能 :通过db句柄 得到数据库操作的错误信息

 

int sqlite3_exec{

sqlite3 *db;

const char *sql;

int (*callback)(void *, int char **, char **);

void *arg;

char **errmsg;

};

功能:执行一条sql语句

参数: db 数据库操作句柄

sql:一条sql语句(末尾的分号可省略)

callback:回调函数 是一个函数指针类型 传递的参数是函数名(只有sql为查询语句时 才会执行回调函数)

arg:表示给回调函数传递的参数

errmsg 错误信息

 

返回值 成功SQLITE_OK

 

typedef int (*sqlite3_callback)(void *para, int f_num, char **f_value, char **f_name)

功能:每找到一条记录自动执行一次回调函数

para:传递给回调函数的参数

f_num: 记录中包含的字段数目

f_value:包含每个字段值的指针数组

f_name 包含每个字段名称的指针数组

成功返回0 失败返回-1

 

 

int sqlite3_get_table(sqlite3 *db, const char *sql, char ***resultp, int nrow, int *ncolum, char **errmsg)

 

db:数据库句柄

resultp: 用来指向sql执行结果的指针

nrow:满足条件的记录的数目

ncolumn: 每条记录包含的字段数

errmsg:错误信息指针的地址

返回值: 成功返回0 失败返回错误码

                                                       代码示例

 

功能: 建立一个数据库 对其能进行删减改查的操作

 

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

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

相关文章

【汇编语言】8086、x86-32和C语言【赋值语句 和 数组】的对比学习(王爽学习笔记:5.8段前缀的使用)

0 前言 这里给出两种思路&#xff0c;都比王爽老师书上的做法要简单高效&#xff0c;事实上&#xff0c;理解指令的本质&#xff0c;就能达到灵活应用&#xff0c;这样才能打破规则 题目&#xff1a;将内存ffff:0 - ffff:b的数据&#xff0c;复制到内存ffff:10 - ffff:1b中 备…

signal------SIGCHLD

因为笔者之前的文章里面有错误&#xff0c;今天发现&#xff0c;立马做个修改。在下面我的一段关于sigchld信号相对于直接调用wait函数的好处时&#xff0c;我说调用wait函数要一直检测子进程是否执行完其实是错误的&#xff0c; wait是阻塞函数&#xff0c;当主进程调用wait函…

为什么要学习汇编语言?如何正确学习汇编语言?

汇编语言是计算机系统结构的接口&#xff0c;它介于软硬件之间&#xff0c;学习的时候&#xff0c;必须结合软件和硬件来学习。 1 向上结合高级语言 学习汇编语言的时候&#xff0c;不可孤立学习汇编语言&#xff0c;当今时代很少之间用到汇编语言编程&#xff0c;但是使用汇…

数据库Sqlite3

sqlite3 数据库安装 1. 本地安装 sudo dpkg -i *.deb 2.在线安装 sudo apt-get install sqlite3 SQLITE3 基本命令 两种命令 1.以 . 开头的称之为系统命令 .help 帮助 .quit 退出 .exit 退出 .databases 查看打开的数据库&#xff08;显示数据库的名字和路径&#xff…

【汇编语言】(王爽)实验4解答

题目1 编程&#xff1a;向内存0:200 - 0:23F 中存放数据 0 - 3FH ; 向内存 0:200 ~ 0:23f 写入数据0~3fH【字节型数据】 assume cs:code code segmentstart:mov ax,0mov ds,axmov bx,0200H ; 偏移地址mov al,0 ; 数据mov cx,03fH1H ; 0 ~ 3FH 共 (3F 1)Hs:mov [bx],alinc b…

软考安全工程师历年真题汇总

2019年上半年信息安全工程师考试真题与答案&#xff08;下午题&#xff09; https://blog.csdn.net/jayjaydream/article/details/90683127 2018年上半年信息安全工程师考试真题与答案&#xff08;上午题&#xff09; https://www.moondream.cn/?p681 2018年上半年信息安全工…

【汇编语言】8086汇编,快速搞定各种寻址方式:立即数寻址 / 寄存器寻址 / 存储器寻址

0 前言 众所周知&#xff0c;对于8086汇编语言&#xff0c;有几大寻址方式&#xff0c;不过我觉得这个好墨迹&#xff0c;会用就可以了&#xff0c;为什么命名这么多&#xff0c;这次只说本质&#xff0c;不说命名&#xff0c;至于命名&#xff0c;还是得知道&#xff0c;毕竟…

信息安全工程师考试大纲(含pdf)

PDF文件下载链接&#xff1a; https://pan.baidu.com/s/1nSLBGfBc8HzFwE0xk9FzcQ 提取码&#xff1a;9udy 信息安全工程师考试大纲 1&#xff0e;信息安全基本知识 1.1 信息安全概念 ● 了解网络空间的概…

【数据库】数据库基本概念:数据库管理系统 / 数据库 / 表 / 数据

0 前言 本文讲解数据库的最基本概念 推荐书籍&#xff1a;《MySQL 必知必会》 需要的软件&#xff1a;MySQL 8.0 1 数据库相关概念及其实战应用 1.1 数据&#xff08;Data&#xff09; 在人类世界中&#xff0c;数据可以是 数值型数据 十进制数 非数值型数据 图片声音视频文…

tiny4412初期环境搭建

花了整整三天 从跃跃欲试到失望 绝望 最后迎来曙光!!! 话不多说直接上干货 这些软件安装的具体过程网上有很多 在这里就不说了 1.在主机下 安装secureCRT软件和超级终端&#xff08;安一个就行 不过最好两个都安上&#xff09; 作用&#xff1a; 软件可以打印一些开发板信息…

vivado软件如何查看内部器件的仿真信号

有时候&#xff0c;我们需要查看内部模块的信号&#xff0c;那么&#xff0c;在vivado软件该如何操作呢&#xff1f; 运行仿真&#xff0c;可以得到这个界面&#xff0c;之后看左侧部分&#xff0c;可以查看内部的模块。 例如单击rom0 可以看见其内部信号&#xff0c;然后在想…

通过Source insight查看内核源码

1.下载源码 https://www.kernel.org/pub/linux/kernel/ 下载后解压即可 2.打开SourceInsight,创建工程 点击顶部Project菜单 3.将源码文件导入工程 4.查看源码

蓝桥杯物联网例程下载

今年是蓝桥杯物联网的第一届 我也是赶快买了物联网的开发板 这是附带的例程和一些综合实验 仅供参考练习 里面所有的例程大概花了两周实现了大部分&#xff08;有一些例如ADC和PWM的 手头没有示波器和电压表就没有做&#xff09; 我比较懒 不喜欢做每个例程的教程 就统一分享出…

Vivado软件(用VerilogHDL)如何使用$readmemh和$readmemb函数

0 前言 博主我查了很多资料&#xff0c;虽然会使用Verilog的readmemh和readmemh和readmemh和readmemb函数&#xff0c;可是&#xff0c;在vivado软件中怎么用&#xff1f;文件放在哪里&#xff1f;没有一篇文章提及。 花了几个小时&#xff0c;终于研究明白了&#xff0c;特此…

【汇编语言】王爽第六章程序6.3解答,8086汇编语言实现数据的倒序存放

程序很简单&#xff0c;就是利用栈&#xff0c;实现数据的倒序存放。 ; 将数据逆序存放 assume ds:data data segment dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h data endsassume ss:stack stack segmentdw 0,0,0,0,0,0,0,0 stack endsassume cs:code code segmen…

---------愿 青春与我皆不付---------------------

2019年8月4日晚 21点51 我愿以此用博客来记录我的学习之路 void mian(void) { while(1) { run(); } } 不负光阴 不负卿

【汇编语言】快速理解什么是寻址,什么是寻址方式

0 前言 有很多专业的资料讲述这些概念&#xff0c;但是&#xff0c;虽然很专业&#xff0c;但是初学者根本看不懂&#xff01; 因此在这里&#xff0c;我用最简单的方式&#xff0c;告诉你 什么是寻址什么是寻址方式 1 计算机的极简模型 计算机的世界中&#xff0c;只有二…

【汇编语言】程序设计过程,如何避免数据类型匹配错误?

真言&#xff1a;操作数据&#xff0c;先看方式&#xff0c;再对应解决 0 前言 对于x86系列的汇编语言&#xff0c;AT&T格式需要使用后缀指明操作数的数据类型&#xff0c;Intel格式并没有这样的规定&#xff0c;但是&#xff0c;数据类型还是必须匹配&#xff0c;这就导…

【汇编语言】王爽实验5(5)(6)的解答 建立数据类型匹配的观念

0 前言 本文解答王爽《汇编语言》实验5的&#xff08;5&#xff09;&#xff08;6&#xff09;题 同时给出一些常见问题的解答 以及给出最易犯错的地方&#xff1a;数据类型不匹配的解决方案 1 题目解答 1.1 实验5&#xff08;5&#xff09; 1.1.1 题目 将data1和data2段…

【Java图文趣味版】快速搞定数组的声明、开辟空间和初始化赋值

0 前言 本文讲解java数组的基础知识&#xff0c;适合零基础小白。 1 数组的概念 所谓数组&#xff0c;就是一组同类型东西的集合&#xff0c;可以通过index&#xff08;索引&#xff0c;下标&#xff09;访问这一组东西的某一个元素。 就像下图这样&#xff0c;由于数组概念…