回顾:
DDL
表的创建、修改、删除
create table 表名(字段名 字段类型 [约束],...);
alter table 表名 {rename to 新名字 | add column 字段 字段类型};
drop table 表名 ;
DML
记录的增、删、改、查
insert into 表名(字段名,...)values(字段值,...);
insert into 表名 values(字段值,...);

delete from 表名 [where 条件];

update 表名 set 字段=新值 [where 条件];

select * from 表名 [where 条件];

------------------------------------------
sqlite3接口函数

sqlite3 数据库连接对象
sqlite3_stmt 编译后的SQL语句对象
sqlite3_open() 打开或创建一个数据库连接
sqlite3_prepare() 准备SQL语句
sqlite3_bind() 绑定参数
sqlite3_step() 执行准备好的SQL语句
sqlite3_column() 从sqlite3_stmt中取字段值
sqlite3_finalize() 用来释放sqlite3_stmt
sqlite3_close() 关闭数据库
sqlite3_exec() 执行SQL语句

------------------------------------
sqlite3
sqlite3_open
sqlite3_exec
sqlite3_close
sprintf()
-------------
数据库的操作流程:
1.连接数据库
sqlite3 *db;
2.打开数据库
int sqlite3_open(
const char *filename, /* 数据库名(字符串类型) */
sqlite3 **ppDb /* sqlite3结构二级指针,数据库连接对象 */
);
返回值:成功返回 SQLITE_OK,并且ppDb指向新的数据库连接
其它值表示失败

例:
int res = sqlite3_open("test.db",&db);
if(res != SQLITE_OK)
{
printf("open db err:%s\n",sqlite3_errmsg(db));
sqlite3_close(db);
return -1;
}
3.操作
int sqlite3_exec(
sqlite3*, 打开的数据库
const char *sql, 要执行的SQL语句(字符串)
int (*callback)(void*,int,char**,char**), 回调函数
void *, 做为回调函数的第一个参数
char **errmsg 错误信息写在这里
)
SQL语句的执行分为两类:
a.没有返回结果的情况,那么就不需要回调函数,给NULL即可
如:create insert update delete...
b.有结果集返回的情况,那么就需要通过回调函数去获取结果集
每查到一条记录调用一次回调函数
如:select

int (*callback)(void* arg,传给回调函数的参数
int column_count,记录的字段(例)个数
char**column_value,字段值(就是个一维数组)
char**column_name)字段名(一维数组)
例:
char* column_name[3] = {"abc","123","hello"};

4.关闭数据库
int sqlite3_close(sqlite3*);

id name age addr

1000 白起 20 CHINA
1001 李牧 21 CHINA
1002 王箭 21 CHINA
1003 廉颇 25 CHINA

gcc sqlite3_exec_select.c
-I /usr/local/sqlite3/PC/include/ 指明头文件所在目录
-L /usr/local/sqlite3/PC/lib/ 指明库所在目录
-lsqlite3 所用的库的名字

------------------------------------------------------------------------
sqlite3 数据库连接对象
sqlite3_stmt 编译后的SQL语句对象
sqlite3_open() 打开或创建一个数据库连接
sqlite3_prepare() 准备SQL语句
sqlite3_bind() 绑定参数
sqlite3_step() 执行准备好的SQL语句
sqlite3_column() 从sqlite3_stmt中取字段值
sqlite3_finalize() 用来释放sqlite3_stmt
sqlite3_close()

1.打开数据库,建立连接
2.准备SQL语句
(如果SQL语句有可变的参数,那就要绑定值)
int sqlite3_prepare_v2(
sqlite3 *db, /* 数据库连接对象 */
const char *zSql, /* 要执行的SQL语句 */
int nByte, /* SQL语句的长度 */ 可以为负数(-1),自动计算长度
sqlite3_stmt **ppStmt, /* 准备好的SQL语句 */
const char **pzTail /* 指向未执行的SQL语句*/
);
char *zSql = "create table....;intser into...";
char *pzTail = "intser into...";

3.执行
(如果是查询语句,那就需要获取结果集)
int sqlite3_step(sqlite3_stmt*);
执行成功返回SQLITE_DONE
如果有数据返回时,执行成功返回SQLITE_ROW

4.释放sqlite3_stmt对象
int sqlite3_finalize(sqlite3_stmt *pStmt);
5.关闭

-----------------
int sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int n, void(*)(void*));
int sqlite3_bind_double(sqlite3_stmt*, int, double);
int sqlite3_bind_int(sqlite3_stmt*, int, int);
int sqlite3_bind_null(sqlite3_stmt*, int);
int sqlite3_bind_text(sqlite3_stmt*,int,const char*,int,void(*)(void*));

第一、二个参数和返回值都是相同的:
第一个参数:解析后的语句对象
第二个参数:是要绑定的参数的索引号,从索引值1开始
第三个参数:要给参数绑定的值
第四个参数(如果有):代表第三个参数的绑定值的长度
第五个参数(如果有):是一个指向内存管理的回调函数的指针,一般给0
回调函数:void callback(void*);

练习:
用sqlite3_bind_blob,往数据库里存取图片

const void *sqlite3_column_blob(sqlite3_stmt*, int iCol);
int sqlite3_column_bytes(sqlite3_stmt*, int iCol);

double sqlite3_column_double(sqlite3_stmt*, int iCol);
int sqlite3_column_int(sqlite3_stmt*, int iCol);
const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol);
int sqlite3_column_count(sqlite3_stmt *pStmt);

int sqlite3_column_type(sqlite3_stmt*, int iCol);
返回五个存储类型对应的整数值:
SQLITE_INTEGER 1
SQLITE_FLOAT 2
SQLITE_TEXT 3
SQLITE_BLOB 4
SQLITE_NULL 5

/*************************************************************************
> File Name: sqlite3_exec.c
> Author: csgec
> Mail: longer.zhou@gmail.com
> Created Time: Thu 25 Aug 2016 10:07:00 AM CST
************************************************************************/

#include<stdio.h>
#include<sqlite3.h>

int main()
{
//1.打开数据库,并建立数据库连接
sqlite3 *db;
int res = sqlite3_open("test.db",&db);
if(res != SQLITE_OK)
{
fprintf(stderr,"open err:%s\n",sqlite3_errmsg(db));
sqlite3_close(db);
return -1;
}
printf("打开数据库test.db成功~~\n");

//2.操作数据库,建表,增 删 改 查等操作
char *createSql = "create table if not exists stud(id integer primary key,name text not null,age integer check(age>6),addr text default 'CHINA')";
char *errmsg = NULL;
res = sqlite3_exec(db,createSql,NULL,NULL,&errmsg);
if(res != SQLITE_OK)
{
fprintf(stderr, "SQL error: %s\n", errmsg);
sqlite3_free(errmsg);
}
printf("建表 stud 成功~\n");

//3.关闭数据库
sqlite3_close(db);
return 0;
}

/*************************************************************************
> File Name: sqlite3_exec_select.c
> Author: csgec
> Mail: longer.zhou@gmail.com
> Created Time: Thu 25 Aug 2016 10:07:00 AM CST
************************************************************************/

#include<stdio.h>
#include<sqlite3.h>

int callback(void*arg,int column_count,char **column_value,char** column_name)
{
printf("字段数:%d\n",column_count);
int i;
for(i = 0; i < column_count; i++)
{
printf("字段名:%s\t",column_name[i]);
}
printf("\n");

for(i = 0; i < column_count; i++)
{
printf("%s\t",column_value[i]);
}
printf("\n");

return 0;
}
int main()
{
//1.打开数据库,并建立数据库连接
sqlite3 *db;
int res = sqlite3_open("test.db",&db);
if(res != SQLITE_OK)
{
fprintf(stderr,"open err:%s\n",sqlite3_errmsg(db));
sqlite3_close(db);
return -1;
}
printf("打开数据库test.db成功~~\n");

//2.操作数据库,建表,增 删 改 查等操作
// char *createSql = "create table if not exists stud(id integer primary key,name text not null,age integer check(age>6),addr text default 'CHINA')";

char *selectSql = "select * from stud";
char *errmsg = NULL;
res = sqlite3_exec(db,selectSql,callback,NULL,&errmsg);
if(res != SQLITE_OK)
{
fprintf(stderr, "SQL error: %s\n", errmsg);
sqlite3_free(errmsg);
}
printf("建表 stud 成功~\n");

//3.关闭数据库
sqlite3_close(db);
return 0;
}

/*************************************************************************
> File Name: sqlite3_prepare.c
> Author: csgec
> Mail: longer.zhou@gmail.com
> Created Time: Thu 25 Aug 2016 02:23:03 PM CST
************************************************************************/

#include<stdio.h>
#include<sqlite3.h>
#include<string.h>
int main()
{
sqlite3 *db;
sqlite3_stmt *stmt;
//1
int res = sqlite3_open("test.db",&db);
if(res != SQLITE_OK)
{
fprintf(stderr,"open error %s\n",sqlite3_errmsg(db));
sqlite3_close(db);
return -1;
}
printf("打开数据库test.db成功~\n");

//2.
int id;
char name[32] = {0};
int age;
char *insertSql = "insert into stud(id,name,age) values(?,?,?);";
printf("请输入ID:\n");
scanf("%d",&id);
printf("请输入姓名:\n");
scanf("%s",name);
printf("请输入年龄:\n");
scanf("%d",&age);
res = sqlite3_prepare_v2(db,insertSql,strlen(insertSql),&stmt,0);
if(res != SQLITE_OK)
{
printf("sqlite3_prepare_v2 error\n");
fprintf(stderr,"prepare error %s\n",sqlite3_errmsg(db));
return -1;
}
sqlite3_bind_int(stmt,1,id);
sqlite3_bind_int(stmt,3,age);
sqlite3_bind_text(stmt,2,name,strlen(name),0);

//3
res = sqlite3_step(stmt);
if(res != SQLITE_DONE)
{
printf("sqlite3_step error\n");
return -1;
}
//4
sqlite3_finalize(stmt);
sqlite3_close(db);
}

/*************************************************************************
> File Name: sqlite3_prepare_select.c
> Author: csgec
> Mail: longer.zhou@gmail.com
> Created Time: Thu 25 Aug 2016 02:23:03 PM CST
************************************************************************/

#include<stdio.h>
#include<sqlite3.h>
#include<string.h>
int main()
{
sqlite3 *db;
sqlite3_stmt *stmt;
//1
int res = sqlite3_open("test.db",&db);
if(res != SQLITE_OK)
{
fprintf(stderr,"open error %s\n",sqlite3_errmsg(db));
sqlite3_close(db);
return -1;
}
printf("打开数据库test.db成功~\n");

//2.
char *selectSql = "select * from stud;";
res = sqlite3_prepare_v2(db,selectSql,strlen(selectSql),&stmt,0);
if(res != SQLITE_OK)
{
printf("sqlite3_prepare_v2 error\n");
fprintf(stderr,"prepare error %s\n",sqlite3_errmsg(db));
return -1;
}

//3
res = sqlite3_step(stmt);
/*
if(res != SQLITE_DONE)
{
printf("sqlite3_step error\n");
return -1;
}
*/
int count = sqlite3_column_count(stmt);
printf("count = %d\n",count);
int i;
//获取字段名和字段类型
for(i = 0; i < count; i++)
{
printf("column name:%s\n",sqlite3_column_name(stmt,i));
printf("column type:%i\n",sqlite3_column_type(stmt,i));
}

//获取字段值
int id;
const char *name;
int age;
const char *addr;
while(res == SQLITE_ROW)
{
id = sqlite3_column_int(stmt,0);
name = sqlite3_column_text(stmt,1);
age = sqlite3_column_int(stmt,2);
addr = sqlite3_column_text(stmt,3);
printf("id = %d,name = %s,age = %d,addr = %s\n",
id,name,age,addr);

res = sqlite3_step(stmt);
}
//4
sqlite3_finalize(stmt);
sqlite3_close(db);
}

转载于:https://www.cnblogs.com/liudehao/p/5808177.html

sqlite3API函数相关推荐

  1. 数据库中自定义排序规则,Mysql中自定义字段排序规则,Oracle中自定义字段排序规则,decode函数的用法,field函数的用法

    数据库中自定义排序 场景:有一张banner表,表中有一个status字段,有0, 1, 2三个状态位,我想要 1,0,2的自定义排序(这里是重点),然后再进行之上对sequence字段进行二次排序( ...

  2. Mysql函数group_concat、find_in_set 多值分隔字符字段进行数据库字段值翻译

    Mysql函数group_concat.find_in_set进行数据库字段值翻译 场景 配方表:记录包含的原料 sources表示原料,字段值之间用逗号分隔 原料表:对应原料id和原料名称 现需要查 ...

  3. C++ 笔记(34)— C++ exit 函数

    当遇到 main 函数中的 return 语句时,C++ 程序将停止执行.但其他函数结束时,程序并不会停止.程序的控制将返回到函数调用之后的位置.然而,有时候会出现一些非常少见的情况,使得程序有必要在 ...

  4. C++ 笔记(30)— 友元函数与友元类

    我们知道类的私有成员只能在类的成员函数内部访问,如果想在别处访问对象的私有成员,只能通过类提供的接口(成员函数)间接地进行.这固然能够带来数据隐藏的好处,利于将来程序的扩充,但也会增加程序书写的麻烦. ...

  5. 浅显易懂 Makefile 入门 (07)— 其它函数(foreach 、if、call、origin )

    1. foreach 函数 foreach 函数定义如下: $(foreach <var>,<list>,<text>) 函数的功能是:把参数 <list&g ...

  6. 浅显易懂 Makefile 入门 (06)— 文件名操作函数(dir、notdir、suffix、basename、addsuffix、addperfix、join、wildcard)

    编写 Makefile 的时候,很多情况下需要对文件名进行操作.例如获取文件的路径,去除文件的路径,取出文件前缀或后缀等等. 注意:下面的每个函数的参数字符串都会被当作或是一个系列的文件名来看待. 1 ...

  7. Go 学习笔记(65)— Go 中函数参数是传值还是传引用

    Go 语言中,函数参数传递采用是值传递的方式.所谓"值传递",就是将实际参数在内存中的表示逐位拷贝到形式参数中.对于像整型.数组.结构体这类类型,它们的内存表示就是它们自身的数据内 ...

  8. Go 学习笔记(61)— Go 高阶函数、函数作为一等公民(函数作为输入参数、返回值、变量)的写法

    函数在 Go 语言中属于"一等公民(First-Class Citizen)"拥有"一等公民"待遇的语法元素可以如下使用 可以存储在变量中: 可以作为参数传递给 ...

  9. C++ 笔记(26)— 主函数 main(int argc, char *argv[]) 参数说明

    带形参的 main 函数,如 int main( int argc, char* argv[], char **env ) 是 UNIX .Linux 以及 Mac OS 操作系统中 C/C++ 的 ...

最新文章

  1. configure: error: newly created file is older than distributed files!
  2. spring6:bean的生命始末方法
  3. 新瓶装旧酒,贴着区块链标签的QunQun社交平台真能讲个好故事?
  4. RPi 2B python opencv camera demo example
  5. 稳定的货源社区新版云乐购免费开源源码
  6. 150秒内诊断脑瘤!最新医学影像AI在《Nature Medicine》发表
  7. linux命令 recv阻塞时间,linux下close 掉socket 之后 阻塞的recv 不会立即返回
  8. table合并单元格_element ui el-table 合并单元格
  9. MySql 数据库安装、环境变量配置 以及 本地连接
  10. uva live 4394 String painter 区间dp
  11. Python Socket模块实现服务端与客户端通信
  12. 【转】关于ATSC制数字电视机顶盒的…
  13. 会议流程安排以及详细的资料。
  14. 【Collection、List、泛型、数据结构】
  15. 4 行代码写 3 个NPE异常,服了!
  16. 阿里云-GPU/ASK/ACK/NAS/Docker
  17. AcWing4084 号码牌 (并查集 / bitset优化Floyd)
  18. 安卓设置keychain_使用Android KeyChain安全存储对称密钥
  19. linux在根目录下创建目录一test,Linux练习题
  20. foobar2000_修复了在Foobar2000中找不到设备(0x88780078)

热门文章

  1. 4.3---建立高度最小二叉树
  2. 6.LibSVM核函数
  3. c++账户类 题目描述
  4. day for people, night for material
  5. if you go to the station early, what will you get
  6. 要锻炼二手交换的能力
  7. GTK+ VS MFC
  8. MySQL事务的的介绍及使用
  9. python安装requests
  10. CAS 5.2.x 单点登录 - 实现原理及源码浅析