SQLite3 数据库使用

时间:2021-07-03 05:28:03

一、SQLite简介

SQLite 是用C语言编写的开源数据库,主要用于嵌入式,你也可以把它集成在自己的桌面程序中,也有人将其替代Access,用作后台数据库。

SQLite 支持多数SQL92标准,例如:索引、限制、触发和查看支持。

支持 NULL、INTEGER、REAL、TEXT 和 BLOB 数据类型,支持事务。

二、下载SQLite

SQLite可以到官方站点下载

http://www.sqlite.org/download.html

包括:Linux,Mac OS X, Windows下的已编译文件以及源代码、帮助文档。

SQLite浏览工具下载:http://sqliteadmin.orbmu2k.de/

三、SQLite使用

1、 数据库连接、SQL解析接口:

    sqlite3_open(); //以UTF-8方式打开


    sqlite3_prepare()
    sqlite3_step()


    sqlite3_column()


    sqlite3_finalize()


    sqlite3_close()

2、sqlite3_column()

    sqlite3_column_blob()
    sqlite3_column_bytes()
    sqlite3_column_bytes16()
    sqlite3_column_count()
    sqlite3_column_double()
    sqlite3_column_int()
    sqlite3_column_int64()
    sqlite3_column_text()
    sqlite3_column_text16()
    sqlite3_column_type()
    sqlite3_column_value()

3、SQL

    sqlite> create table 数据库 (名字, 嵌入式);
    sqlite> insert into 数据库 values ('SQLite','是');
    ssqlite> select * from 数据库;
    sqlite> update 数据库 set 名字='SQLite3' where 名字='SQLite';
    sqlite> delete from 数据库 where 嵌入式='是';
    sqlite> .separator "-"

4、事务

    result = sqlite3_exec(db, "BEGIN;", 0, 0, 0);

    //批量处理
    for (int i=0; i<10000; i++)
    {
        //插入一条数据
        result = sqlite3_exec(db,
            "INSERT INTO MyTable (MyText, MyDate, MyTime, MyFloat) VALUES ('SQLITE3!',         '2013-07-28', '23:00:00', 1000);",0, 0, 0);
    }

    result = sqlite3_exec(db, "COMMIT;", 0, 0, 0);

5、触发器

    假设"customers"表存储了客户信息,"orders"表存储了订单信息,下面的触发器 确保当用户    改变地址时所有的 关联订单地址均进行相应改变:

    CREATE TRIGGER update_customer_address UPDATE OF address ON customers
      BEGIN
        UPDATE orders SET address = new.address WHERE customer_name = old.name;
      END;

    定义了该触发器后执行如下语句:

    UPDATE customers SET address = '1 Main St.' WHERE name = 'Jack Jones';

    会使下面的语句自动执行:

    UPDATE orders SET address = '1 Main St.' WHERE customer_name = 'Jack Jones';

    注意,目前在有INTEGER PRIMARY KEY域的表上触发器可能工作不正常。若 BEFORE触发器修改    了一行的 INTEGER PRIMARY KEY域,而该域将由触发该触发器 的语句进行修改,则可能根本不    会修改该域。 可以用PRIMARY KEY字段代替 INTEGER PRIMARY KEY字段来解决上述问题。

6、SQL执行 回调 与 不回调

回调方案
int sqlite3_exec ( sqlite3 *db,  // 使用 sqlite3_open () 打开的数据库对象。
               const char *sql, // 一条待查询的 SQL 语句
               sqlite3_callback, // 自定义的回调函数,对查询结果每一行都执行一次这个函数
               void *,
               char **errmsg
);

这是最常用的执行 sql 语句的调用。简单的参数含意标在上面函数中,下面对重
要参数含意详细注释:

 - 第 4 个参数 "void *" 是调用者所提供的指针,可以传递任何一个指针参数到
   这里,这个参数最终会传到回调函数里面,这个指针比较重要,可以用来作参
   数的传递。如果不需要传递指针给回调函数,可以填NULL。等下我们再看回调
   函数的写法,以及这个参数的使用。

 - 第 5 个参数 "char ** errmsg" 是错误信息。注意是指针的指针。sqlite3里
   面有很多固定的错误信息。执行 sqlite3_exec 之后,执行失败时可以查阅这
   个指针(直接 printf(“%s\n”,errmsg))得到一串字符串信息,这串信息告诉
   你错在什么地方。sqlite3_exec函数通过修改你传入的指针的指针,把你提供
   的指针指向错误提示信息,这样sqlite3_exec函数外面就可以通过这个
   char*得到具体错误提示。

说明:通常, sqlite3_callback 和它后面的 void * 这两个位置都可以填
NULL。填NULL表示你不需要回调。比如你做 insert 操作,做 delete 操作,就
没有必要使用回调。而当你做 select 时,就要使用回调,因为 sqlite3 把数据
查出来,得通过回调告诉你查出了什么数据。

** exec 的回调函数

typedef int(*sqlite3_callback) (void *, // 这就是上面函数传递的 void * 参数,需要强制类型转换后才能使用。
                    int, // 查询结果的列数,即有多少个字段数
                    char **, // 保存查询结果
                    char **  // 各个字段的名字
);

不回调方案
int main( int , char ** )
{
          sqlite3 * db;
          int result;
          char * errmsg = NULL;
          char ** dbResult; //是 char ** 类型,两个*号
          int nRow, nColumn;
          int i , j;
          int index;

          result = sqlite3_open( “c:\\database.db”, &db );

         if( result != SQLITE_OK )
        {
               //数据库打开失败
               return -1;
        }

       //数据库操作代码
       //假设前面已经创建了 MyTable_1 表
       //开始查询,传入的 dbResult 已经是 char **,这里又加了一个 & 取地址符,传递进去的就成了 char ***
       result = sqlite3_get_table( db, “select * from MyTable_1”, &dbResult, &nRow, &nColumn, &errmsg );
       if( SQLITE_OK == result )
       {
           //查询成功
          index = nColumn; //前面说过 dbResult 前面第一行数据是字段名称,从 nColumn 索引开始才是真正的数据
     printf( “查到%d条记录\n”, nRow );

     for(  i = 0; i < nRow ; i++ )
     {
         printf( “第 %d 条记录\n”, i+1 );
         for( j = 0 ; j < nColumn; j++ )
         {
              printf( “字段名:%s  ß> 字段值:%s\n”,  dbResult[j], dbResult [index] );
              ++index; // dbResult 的字段值是连续的,从第0索引到第 nColumn - 1索引都是字段名称,从第 nColumn 索引开始,后面都是字段值,它把一个二维的表(传统的行列表示法)用一个扁平的形式来表示
         }
         printf( “-------\n” );
     }
}

     //到这里,不论数据库查询是否成功,都释放 char** 查询结果,使用 sqlite 提供的功能来释放
     sqlite3_free_table( dbResult );

     //关闭数据库
     sqlite3_close( db );
     return 0;
}