sqlite3_open

  • sqlite3_open函数原型:
    1. int sqlite3_open(
    2. const char *filename, /* Database filename (UTF-8) */
    3. sqlite3 **ppDb /* OUT: SQLite db handle */
    4. );
  • sqlite3_open用于连接打开一个数据库,如果这个数据库不存在,则会在指定的路径下创建一个数据库文件,并打开文件;
    1. void main(void) {
      ......
    2.  
    3. sqlite3 *db;
    4. char *zErrMsg = ;
    5. int rc;
    6.  
    7. rc = sqlite3_open("testDB1.db", &db);
    8. if(rc){
    9. fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
    10. exit();
    11. } else {
    12. fprintf(stderr, "Opened database successfully\n");
    13. }
      ......
      }

sqlite3_exec

  • sqlite3_exec函数原型:
    1. int sqlite3_exec(
    2. sqlite3, /* An open database */
    3. const char *sql, /* SQL to be evaluated */
    4. int (*callback)(void*,int,char**,char**), /* Callback function */
    5. void *, /* 1st argument to callback */
    6. char **errmsg /* Error msg written here */
    7. );
  • sqlite3_exec用于执行一条sql语句,参数如下:
  • 参数1:打开数据库得到的指针;
  • 参数2:一条sql语句,是一个以“\0”结尾的字符串;
  • 参数3:用户提供的回调函数,如果不需要回调函数,可以填 NULL。比如做insert 操作,做delete操作,就没有必要使用回调。而当你做select 时,就要使用回调;
  • 参数4:回调函数需要传递的参数,如果不需要,可以填 NULL;
  • 参数5:错误信息
  • 不使用回调示例:
    1. void main(void){
    2. ......
    3. sql = "INSERT INTO COMPANY VALUES (1, 'Paul', 32, 'California', 20000.00 ); "
    4. sqlite3_exec(db, sql, , , &zErrMsg);
    5.  
    6. .....
    7. }
  • 回调示例:
    1. static int callback(void *NotUsed, int argc, char **argv, char **azColName){
    2. int i;
    3. for(i=; i<argc; i++){
    4. printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
    5. }
    6. printf("\n");
    7. return ;
    8. }
    9.  
    10. void main(void){
    11. ......
    12.  
    13. /* Create SQL statement */
    14. sql = "SELECT * from COMPANY";
    15.  
    16. /* Execute SQL statement */
    17. rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
    18. if( rc != SQLITE_OK ){
    19. fprintf(stderr, "SQL error: %s\n", zErrMsg);
    20. sqlite3_free(zErrMsg);
    21. }else{
    22. fprintf(stdout, "Operation done successfully\n");
    23. }
    24.  
    25. ......
    26. }

sqlite3_close

  • sqlite3_close函数原型:

    1. int sqlite3_close(sqlite3*);  
  • sqlite3_close用于在操作完数据库之后,关闭数据库;

sqlite3入门之sqlite3_open,sqlite3_exec,slite3_close的更多相关文章

  1. 数据库(SQLITE3函数总结): sqlite3_open, sqlite3_exec, slite3_close,sqlite3_prepare_v2,sqlite3_column_text,

    Sqlite3 的确非常好用.小巧.速度快.近期研究它,有一些收获,这里把我对 sqlite3 的研究列出来,以备忘记. 导入SQLLite library并引入头文件. libsqlite3.dyl ...

  2. sqlite入门基础(一):sqlite3_open,sqlite3_exec,slite3_close

    打开数据库链接sqlite3_open用法 原型: int sqlite3_open( const char *filename, /* Database filename (UTF-8) */ sq ...

  3. sqlite3 入门

    SQLite3 C语言API入门下载SQLite3 我们下载sqlite源码包,只需要其中的sqlite3.c.sqlite.h即可.最简单的一个创建表操作#include <stdio.h&g ...

  4. python sqlite3 入门 (视频讲座)

    python sqlite3 入门 (视频讲座) an SQLite mini-series! - Simple Databases with Python 播放列表: YouTube https:/ ...

  5. Sqlite3入门简记

    一,安装Sqlite3 1.入门时看http://www.runoob.com/sqlite/sqlite-intro.html,说的简单,但是适合入门 2.在终端输入sqlite3,没有返回信息,表 ...

  6. sqlite3入门之sqlite3_get_table,sqlite3_free_table

    sqlite3_get_table sqlite3_get_table函数原型: int sqlite3_get_table( sqlite3 *db, /* An open database */ ...

  7. sqlite3入门之sqlite3_mprintf

    sqlite3_mprintf sqlite3_mprintf()函数原型: char *sqlite3_mprintf(const char*,...); sqlite3_mprintf()的作用是 ...

  8. [ios]sqlite轻量级数据库学习连接

    SQLLite (一)基本介绍 http://blog.csdn.net/lyrebing/article/details/8224431 SQLLite (二) :sqlite3_open, sql ...

  9. SQLite3简单入门及C++ API

    转载请注明出处:http://www.cnblogs.com/StartoverX/p/4660487.html 项目用到SQLite3,简单记录一下. MySQL不同,SQLite3的数据库基于文件 ...

随机推荐

  1. 一篇文章学会shell脚本

    一.Shell传递参数 #!/bin/bash # 假设在脚本运行时写了三个参数 ..,,则 "(传递了三个参数). echo "-- \$* 演示 --" for i ...

  2. EasyRTMP推送扩展支持HEVC(H265) RTMP推送之Metadata结构填写详解

    我们在<EasyNVR摄像机网页直播中,推流组件EasyRTMP推送RTMP扩展支持HEVC(H.265)的方案>中描述了关于EasyRTMP进行RTMP HEVC(H.265)推流的概括 ...

  3. [LeetCode] 351. Android Unlock Patterns 安卓解锁模式

    Given an Android 3x3 key lock screen and two integers m and n, where 1 ≤ m ≤ n ≤ 9, count the total ...

  4. python:日期计算

    python语言中的datetime模块可以利用其中的方法获取不同的日期,比如获取当前日期.明天.昨天.上个月.下个月和明年.下面利用几个实例说明这些日期的获取方法,操作如下: 第一步,利用datet ...

  5. 浅谈Java中的Condition条件队列,手摸手带你实现一个阻塞队列!

    条件队列是什么?可能很多人和我一样答不出来,不过今天终于搞清楚了! 什么是条件队列 条件队列:当某个线程调用了wait方法,或者通过Condition对象调用了await相关方法,线程就会进入阻塞状态 ...

  6. android基础---->Toast的使用

    简要说明 Toast是一种没有交点,显示时间有限,不能与用户进行交互,用于显示提示信息的显示机制,我们可以把它叫做提示框.Toast不依赖 于Activity,也就是说,没有Activity,依然可以 ...

  7. centos7 intall nvidia driver

    此教程是介绍于 CentOS 7 以上的 Linux 系统中安装 NVIDIA 显卡驱动和 CUDA Toolkit .此文中以 CentOS 7.4 64 bit 为例,显卡型号为 NVIDIA T ...

  8. 前端HTML学习心得

    学习最好的效果就是理论加实践--Hanks!!!(给大家打鸡血的哈哈哈) 前面的学习我教大家怎么搭建简单的前端开发环境,现在我教大家怎么使用工具学习(从入门到放弃哈哈,不不不,这是以前的我,现在我下了 ...

  9. 【LeetCode】寻找两个有序数组的中位数【性质分析+二分】

    给定两个大小为 m 和 n 的有序数组 nums1 和 nums2. 请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n)). 你可以假设 nums1 和 nums2 ...

  10. PAT(B) 1035 插入与归并(Java)

    题目链接:1035 插入与归并 (25 point(s)) 参考博客:PAT乙级--1035(插入排序和归并)java实现熊仙森 题目描述 根据维基百科的定义: 插入排序是迭代算法,逐一获得输入数据, ...