sqlite3API函数
回顾:
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);
}
sqlite3API函数的更多相关文章
- Python 小而美的函数
python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况 any any(iterable) ...
- 探究javascript对象和数组的异同,及函数变量缓存技巧
javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...
- JavaScript权威指南 - 函数
函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...
- C++对C的函数拓展
一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...
- 菜鸟Python学习笔记第一天:关于一些函数库的使用
2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...
- javascript中的this与函数讲解
前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...
- 复杂的 Hash 函数组合有意义吗?
很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...
- JS核心系列:浅谈函数的作用域
一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...
- C++中的时间函数
C++获取时间函数众多,何时该用什么函数,拿到的是什么时间?该怎么用?很多人都会混淆. 本文是本人经历了几款游戏客户端和服务器开发后,对游戏中时间获取的一点总结. 最早学习游戏客户端时,为了获取最精确 ...
随机推荐
- wordpress安装插件--su
Add to Any: Subscribe Button 让读者方便的订阅你的博客到任何Feed阅读器 Google XML Sitemaps 生成完全兼容各大搜索引擎的Sitemaps/网站地图. ...
- hdu_5724_Chess(组合博弈)
题目链接:hdu_5724_Chess 题意: 给你一个n行20列的棋盘,棋盘里面有些棋子,每个棋子每次只能往右走一步,如果右边有棋子,可以跳过去,前提是最右边有格子,如果当前选手走到没有棋子可以走了 ...
- hdu_5555_Immortality of Frog(状压DP)
题目连接:hdu_5555_Immortality of Frog 题意: 给你一个NxN的网格,第N行的每一列都有个青蛙,这些青蛙只会往上走,上帝会在每个膜中放一个长生不老的药,一共有N个膜,每个膜 ...
- ng-bind-html在ng-repeat中问题的解决办法
<div ng-controller="MyCtrl"> Hello, {{name}}! <div class="row" ng-repea ...
- jquery控制audio的播放与暂停
<audio id="audio" src='music.mp3'></audio> <script type="type/javascri ...
- 转 图片缓存之内存缓存技术LruCache,软引用
每当碰到一些大图片的时候,我们如果不对图片进行处理就会报OOM异常,这个问题曾经让我觉得很烦恼,后来终于得到了解决,那么现在就让我和大家一起分享一下吧.这篇博文要讲的图片缓存机制,我接触到的有两钟,一 ...
- winxp iis5中修改最大连接数及添加多个站点
winxp iis5中修改最大连接数及添加多个站点 最 近用asp做一些东西,需要用到iis,还需要用photoshop做一些图片.以前都是在win2003下面做,可是photoshop里面很多中文字 ...
- CentOS 6.5搭建Samba服务器
目标需求:在Windows7下访问CentOS 6.5 root用户桌面/ZS文件夹 0.准备工作 关闭防火墙并开启不起动 service iptables stop chkconfig iptabl ...
- 设计一个 iOS 控件
转载自:http://blog.csdn.net/zhangao0086/article/details/45622875 代码的等级:可编译.可运行.可测试.可读.可维护.可复用 前言 一个控件从外 ...
- 最新百度地图支持Fragment(注意事项)(转)
原文: 最新百度地图支持Fragment(注意事项) 开篇:老的百度地图通常都要继承MapActivity,这样不利于代码的可扩展性,再加上Fragment的流行,老的百度地图已经远远不能满足的大 ...