sqlite3_exec
2016-02-16 15:07
471 查看
函数:sqlite3_exec(),称为便捷函数,封装了好多任务。
函数声明:
int sqlite3_exec( sqlite * , const char * sql , sqlite_callback , void *data , char ** errmmsg) ; 其中 sqlite* 表示打开的数据库;
sql 为执行的sql语句;
callback回调函数;
void *data为回调函数的第一个参数指向提供给回调函数的应用程序特定的数据,也是回调函数的第一个参数; errmsg 为错误信息,是指向错误消息字符串的指针 。
sqlite_exec() 有两个错误消息来源,返回值和可读的字符串errmsg。
注意:如果提供 了errmsg,用来创建错误消息的内存是在堆上分布的。 故在调用后,应该检查一下是否为null值,如果有错误发生,使用sqlite3_free()释放errmsg占用的内存。
在简单命令中使用sqlite3_ exec( ),实例代码:
回调函数的声明:
typedef int ( * sqlite3_callback ) (void * , int , char ** ,char ** );其中void *是为sqlite3_exec()第四个参数提供的数据,int代表字段的数目,char** 便是行中字段名称的字符串的数组,char**表示字段ing成的字符串数组。
sqlite3_exec( )允许执行一批命令,并可以通过回调接口收集所有的返回数据。
函数声明:
int sqlite3_exec( sqlite * , const char * sql , sqlite_callback , void *data , char ** errmmsg) ; 其中 sqlite* 表示打开的数据库;
sql 为执行的sql语句;
callback回调函数;
void *data为回调函数的第一个参数指向提供给回调函数的应用程序特定的数据,也是回调函数的第一个参数; errmsg 为错误信息,是指向错误消息字符串的指针 。
sqlite_exec() 有两个错误消息来源,返回值和可读的字符串errmsg。
注意:如果提供 了errmsg,用来创建错误消息的内存是在堆上分布的。 故在调用后,应该检查一下是否为null值,如果有错误发生,使用sqlite3_free()释放errmsg占用的内存。
在简单命令中使用sqlite3_ exec( ),实例代码:
int main( int argc , char ** argv ) { sqlite3 *db; char *zErr ; nt rc ; char *sql; rc = sqlite3_open_v2( "test.db" , &db); if( rc) { fprintf(stderr , " Can't open database :%s\n" , sqlite3_errmsg(db)); sqlite3_close(db); exit(1); } sql="create table episodes(id int , name text ) "; rc = sqlite3_exec(db , sql, NULL , NULL , &zErr ) ; if(rc ! = SQLITE_OK) { if( zErr != NULL ) { fprintf( stderr , " SQL error : %s\n " , zErr); sqlite3_free(zErr) ; } } sql = "insert into episodes values ( 10,'the dinner party ' )"; rc = sqlite3_exec(db , sql , NULL ,NULL , &zErr); sqlite3_close(db) ; return 0 ; }
回调函数的声明:
typedef int ( * sqlite3_callback ) (void * , int , char ** ,char ** );其中void *是为sqlite3_exec()第四个参数提供的数据,int代表字段的数目,char** 便是行中字段名称的字符串的数组,char**表示字段ing成的字符串数组。
sqlite3_exec( )允许执行一批命令,并可以通过回调接口收集所有的返回数据。
相关文章推荐
- [转载]数据库对象
- sqlite
- sqlserver默认数据库作用
- Redis缓存数据库
- 配置SQL Server ODBC数据源
- 利用MySQL 的GROUP_CONCAT函数实现聚合乘法
- 深入理解SQL的四种连接-左外连接、右外连接、内连接、全连接
- Mysql 查询优化
- Oracle 查看表空间的大小及使用情况sql语句
- MySQL错误中无法连接 MySQL server (10060)
- 答:SQLServer DBA 三十问之一: char、varchar、nvarchar之间的区别(包括用途和空间占用);xml类型查找某个节点的数据有哪些方法,哪个效率高;使用存储 过程和使用T-SQL查询数据有啥不一样;
- mongodb的应用场景
- mysql
- mongodb 关系、引用、覆盖索引查询
- MAC下安装与配置MySQL
- 实例理解SQL中truncate和delete的区别
- sql server tempdb 空间释放
- 数据库schema的简介
- 消息队列服务器 memcacheq的搭建
- SQL常用命令