美文网首页
sqlite3学习笔记

sqlite3学习笔记

作者: AmberXiao | 来源:发表于2018-04-25 10:57 被阅读0次

    c语言 API接口

    打开数据库

    sqlite3_open_v2() 、sqlite3_open() 、sqlite3_open16()

    int sqlite3_open_v2(
      const char * filename ,   //数据库名
      sqlite3 * ppDb ,          //数据库句柄
      int flags ,                   //对数据库的操作权限
      const char * zVfs             //允许调用去重写默认的操作系统接口sqlite3_vfs方法
    );
    

    数据库成功打开则返回SQLITE_OK,否则返回错误码。
    若数据库不存在,且flags包含SQLITE_OPEN_CREATE,则会创建新数据库。

    语句操作

    int sqlite3_prepare_v2(         //将sql语句转换为准备语句
      sqlite3*db,               //数据库句柄
      const char*zSql,              //sql语句
      int nByte,                    //如果nByte小于0,则函数取出zSql中从开始到第一个0终止符的内容;
      //如果nByte不是负的,那么它就是这个函数能从zSql中读取的字节数的最大值。
      //如果nBytes非负,zSql在第一次遇见’/000/或’u000’的时候终止
      sqlite3_stmt **ppStmt,        // 返回的状态句柄
      const char**pzTail            //上面提到zSql在遇见终止符或者是达到设定的nByte之后结束,
      //假如zSql还有剩余的内容,那么这些剩余的内容被存放到pZTail中,不包括终止符
    );
    
    int sqlite3_exec(
      sqlite3 *db,                        /* An open database 数据库句柄  */
      const charchar *sql,                 /* SQL to be evaluated 要执行的操作  */
      int (*callback)(void*,int,char**,char**),  /* Callback function 回调函数的指针*/  
      voidvoid *,                        /* 1st argument to callback 传给回调函数的参数  */
      charchar **errmsg                  /* Error msg written here  错误信息*/
    );
    
    sqlite3_get_table(
      sqlite3 *db,            /* An open database 数据库句柄*/
      const char *zSql,       /* SQL to be evaluated 要执行的操作*/
      char ***pazResult,      /* Results of the query 执行结果,一维数组*/
      int *pnRow,           /* Number of result rows written here 行数*/
      int *pnColumn,        /* Number of result columns written here 列数*/
      char **pzErrmsg       /* Error msg written here 错误信息*/
    );
    
    int sqlite3_column_count(   //计算prepare函数返回结果的列数
    sqlite3_stmt **ppStmt
    );
    
    int sqlite3_column_int(  //step执行完后的结果集中返回指定列的值
      sqlite3_stmt **ppStmt,//状态句柄
      int col  //想要返回列的索引值
    };
    
    int sqlite3_step(       //执行由前面sqlite3_prepare创建的准备语句。
    //这个语句执行到结果的第一行可用的位置。
    //继续前进到结果的第二行的话,只需再次调用sqlite3_setp()。
    //继续调用sqlite3_setp()直到这个语句完成
      sqlite3_stmt **ppStmt  //prepare返回的状态句柄
    );
    
    int sqlite3_finalize(//销毁前面被sqlite3_prepare创建的准备语句,
    //每个准备语句都必须使用这个函数去销毁以防止内存泄露。
      sqlite3_stmt *pStmt  //prepare返回的状态句柄
    );
    
    int sqlite3_reset(
       sqlite3_stmt *pStmt  //prepare返回的状态句柄
    );
    //如果之前没有执行sqlite3_step,
    //或者执行了之后返回SQLITE_DONE、SQLITE_OK、SQLITE_ROW中的一个
    //则调用sqlite3_reset会将stmt返回到prepare刚执行之后的状态
    //若调用了step函数并且出错,则使用reset会返回一个错误值
    
    绑定值

    (为啥要绑定?)
    在一条带参数的prepare之后,step之前,可以给每一个stmt参数绑定一个指定的值。如果一条语句已经调用step执行了,就不能绑定值了,除非这条语句被重置。
    一共有9个bind函数,所有这些函数的第1个参数和第2个参数的返回值都是相同的。第一个参数是指向sqlite3_stmt的指针,第二个参数是要绑定的值的索引值,从1开始,第三个参数是要给stmt绑定的值。第四个参数(有的话)代表第三个参数“绑定值”的字节长度。第五个参数(有的话)是指向内存管理回调函数的指针。
    以上9个函数,如果执行成功则返回SQLITE_OK,否则返回错误码

    int sqlite3_bind_init(sqlite3_stmt *, int, int)//绑定一个32位有符号整型值
    int sqlite3_bind_blob(sqlite3_stmt*,const void *,int, void*(void *))
    //绑定任意长度的blob类型的二进制数据
    //blob:二进制大对象,相当于可以存储大量二进制数据的容器
    int sqlite3_bind_text(sqlite3_stmt*, int, const char*, int n, void(*)(void*));
    //绑定一个任意长度的UTF-8编码的文本值,第4个参数是字节长度,注意不是字符长度。
    //如果给第4个参数传递负值,SQlite就会自动计算绑定值的字节长度(不包括NULL结尾符)
    //第五个参数为一个函数指针,SQLITE3执行完操作后回调此函数,通常用于释放字符串占用的内存
    //第五个参数为SQLITE_STATIC时,表示绑定的字符串为常量
    //第五个参数为SQLITE_TRANSIENT时,表示需要拷贝一份字符串
    

    其他函数见:
    https://blog.csdn.net/northcan/article/details/7235519

    sqlite操作

    PRAGMA语句是SQLITE数据的SQL扩展,是它独有的特性,主要用于修改SQLITE库或者内数据查询的操作
    详细用法参见:
    http://iihero.iteye.com/blog/1189633

    limit

    select * from tablename where ... order by ... limit m offset n
    select * from tablename where ... order by ... limit n,m
    //m表示要显示多少条记录,n表示要跳过多少记录,
    //limit 3 offset 5 表示从第6条开始显示3条记录,即第6、7、8条
    

    order by

    select * from tablename order by asc//升序
    select * from tablename order by desc//降序
    

    相关文章

      网友评论

          本文标题:sqlite3学习笔记

          本文链接:https://www.haomeiwen.com/subject/crselftx.html