对数据库的操作 <打开->操作->关闭>

1.sqlite3_open


    int sqlite3_open(
        const char *filename,   /* Database filename (UTF-8) */
        sqlite3 **ppDb          /* OUT: SQLite db handle */
    );
    功能:
        打开数据库文件(创建一个数据库连接)
    参数:
        filename:数据库文件路径 
        ppDb:操作数据库指针存放空间的首地址
    返回值:
        成功返回SQLITE_OK
        失败返回错误码

2.sqlite3_close 


    int sqlite3_close(sqlite3*);
    功能:
        关闭数据库连接

3.sqlite3_exec 


    int sqlite3_exec(
        sqlite3*,                                  /* An open database */
        const char *sql,                           /* SQL to be evaluated */
        int (*callback)(void*,int,char**,char**),  /* Callback function */
        void *,                                    /* 1st argument to callback */
        char **errmsg                              /* Error msg written here */
    );
    功能:
        执行一条SQL语句
    参数:
        sqlite3*: 数据库句柄
        sql: 要执行的SQL语句字符串首地址
        callback: 只有在select时才会使用,其余调用时传递NULL
        void*: 给回调函数的传参
        errmsg:出错信息存放空间首地址(使用完毕后使用sqlite3_free释放空间)
    返回值:
        成功返回SQLITE_OK
        失败返回错误码 

4.调试段错误:


    1.根据给定链接设置系统允许生成core文件
    2.编译代码时加入-g选项
        gcc filename.c -g -lsqlite3 
    3.执行代码让代码产生段错误(会生成一个包含错误信息的core文件)
    4.使用gdb调试core文件
        gdb a.out core 
    5.可以直接看到产生段错误的代码的位置

 

/******************************************************************

*功能:回调函数 callback

*

*注意:

* 1.找到匹配的数据时才会调用该回调函数,如果该函数没有被调用

* 2.说明未找到匹配的数据

* 3.每找到一个符合条件的数据就会调用一次callback

* 4.参数含义:

* arg:sqlite3_exec的第4个参数

* col:找到的数据有几列

* pcontent:找到的这几列数据字符串首地址的指针数组

* ptitle:找到的这几列标题字符串首地址的指针数组

*****************************************************************/

int callback(void *arg, int col, char **pcontent, char **ptitle)
{
	int i = 0;
	
	printf("===================================\n");
	for (i = 0; i < col; i++)
	{
		printf("%s = %s\n", ptitle[i], pcontent[i]);
	}
	printf("===================================\n");
		
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值