sqlite3

  1. sqlite相关的命令

.tables 查看数据库中的表

.headers on/off 开启或者关闭表头

.mode column 列对齐

.width 列宽1 列宽2 设置每一列的列宽

.schema 表名 查看表的结构

  1. sqlite的SQL语句

每个sql语句后面必须要有一个;

INTEGER : 整形

REAL: 浮点型

TEXT:文本类型,字符串

NULL : 空

  1. 1.创建表

create table 表名(列名1 数据类型 ,列名2 数据类型, 类名3 数据类型) ;

2.2. 插入数据

insert into 表名 values(值1, 值2, 值3);

2.3. 查询

select 列名1,列名2 from 表名;

select * from 表名;

条件查找:

select * from 表名 where 列 关系运算符 值;

关系运算符:

like : 模糊匹配

% 可以通配多个字符

_ 只能通配一个字符

升序排列

select * from 表名 order by 列名 ASC;

降序排列:

select * from 表名 order by 列名 DESC;

    1. 删除一行

delect from 表名 where 列名 关系运算符 值;

    1. 删除一张表

drop 表名;

2.6. 修改

update 表名 set 列名=新值 where 列=值;

    1. 设置主键值自动增长列
  1. 主键值自动增长列的数据类型必须是INTEGER

  2. 类名 INTEGER PRIMARY KEY AUTOINCREMENT,

2.8 .多表联查

内连接 INNER JOIN

外连接 LEFT OUTER JOIN

  1. sqlite3提供的c/c++ API接口

int sqlite3_open(

const char *filename, /* Database filename (UTF-8) */

sqlite3 **ppDb /* OUT: SQLite db handle */

);

功能:打开数据库,如果不存在,则创建

参数:

filename : 数据库名称

ppDb :保存数据库句柄的地址

返回值:

成功:SQLITE_OK

失败:错误码

int sqlite3_exec(

sqlite3*pdb, /* An open database */

const char *sql, /* SQL to be evaluated */

int (*callback)(void*,int,char**,char**), /* Callback function */

void *arg, /* 1st argument to callback */

char **errmsg /* Error msg written here */

);

功能:执行sql语句

参数:

pdb : 数据库句柄

sql : 要执行的sql语句的首地址

callback : 当执行select语句时,使用到

arg:当执行select语句时,使用到,传递给回调函数的第一个参数

errmsg :存储错误信息的地址

返回值:

成功:SQLITE_OK

失败:错误码

int (*callback)(void*,int column_cnt,char**column_value,char**column_name),

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

功能:在使用sqlite3_exec执行select语句时, 每查找到一条数据,则调用一次回调

参数:

arg : sqlite3_exec传递的第4个参数

column_cnt: 查找到的数据的列数

column_value: 查找到的一行数据的每一列值的地址的集合

column_name:查找到的一行数据的每一列列名的地址的集合

返回值:

0

注意:1.每找到一行,回调被触发一次

  1. 回调函数必须返回0;

创建表格

查找

相关推荐
泯仲14 分钟前
从零起步学习MySQL 第二章:DDL语句定义及常见用法示例
数据库·mysql
Leon-Ning Liu14 分钟前
记录MySQL 主从架构切换双主(互为主从)操作步骤
数据库·mysql
@insist12315 分钟前
数据库工程师核心 TCP/IP 协议栈知识:从软考考点到运维实战
运维·数据库·网络协议·tcp/ip·软考·数据库系统工程师·软件水平考试
!chen15 分钟前
Oracle数据库物理备份工具支持本机+异机
数据库
前进的李工1 小时前
数据库视图:数据安全与权限管理利器
开发语言·数据库·mysql·navicat
what丶k1 小时前
深度解析 Canal 数据同步:原理、实操与生产级最佳实践
数据库·后端
白鲸开源1 小时前
(三)ODS/明细层落地设计要点:把数据接入层打造成“稳定可运维”的基础设施
大数据·数据结构·数据库
程序员这么可爱1 小时前
MySQL分页踩坑实录:LIMIT分页出现重复数据,同一主键ID跨页重复完美解决
数据库·mysql·limit分页重复·sql分页优化·数据库踩坑·主键排序规范
Elastic 中国社区官方博客1 小时前
需要知道某个同义词是否实际匹配了你的 Elasticsearch 查询吗?
大数据·数据库·elasticsearch·搜索引擎·全文检索
熊文豪2 小时前
MySQL迁移的“隐形坑”与电科金仓的“零改造”破局之道
数据库·mysql