sqlite数据库相关总结

1.

sqlite是轻量型、关系型管理系统,是嵌入式的,占用资源低、可移植性强,比mySql处理速度快,现在主流的版本是sqlite3

2.

sqlite中的数据类型有TEXT(字符串,采用UTF-8,UTF-16编码)、(REAL)浮点型、(INTEGER)有符号的整型、(BLOB)大二进制数据,能存放任何二进制数据、还有其他几个不常用的( (VARCHAR、CHAR、CLOB)会转化成TEXT的类型    (FLOAT DOUBLE)转化成REAL类型   (NUMERIC)转化成INTEGER)

注:sqlite中没有布尔型,可以用integer的0和1代替,也没有时间和日期的类型,可以用TEXT,REAL等代替

3.

常用的基本的sql语句有:

------创建表:

           creat table 表名 (字段1,字段2,字段3.......);

-------如果表不存在,再创建

           creat table  if not exists 表名 (字段1,字段2,字段3.......) 

--------删除整张表:

        drop table 表名

--------插入数据:

        insert into 表名 (字段1,字段2,字段3.......)values (值1,值2,值3......)

---------查询:

        select 字段名 from 表名  ---------》查询某一字段的数据

        select * from 表名  ---------》查询所有字段的所有数据

----------修改:

        update 表名 set 字段名 = '新值' where 查询条件

 

4.写代码之前需要在link frameWorks and libraries 里面添加sqlite3的动态库,在数据库相关操作的类中添加头文件,就可以了。

一般数据库我们要在沙盒的document文件夹下创建一个文件,来作为数据库的保存路径。

5.创建sqlite3 * db 这样一个数据库的对象。sqlite是c语言的类库,函数都为c语言的函数

   打开数据库的方法:

   sqlite3_open([filePath UTF8String], &DB);  -------------》第一个参数为数据库的存储路径,第二个参数为数    据库取地址,是有返回值的,若返回值为SQLITE_OK即打开成功。

   如果数据库打开成功,就可以创建表了,先写sql语句,再用执行函数进行执行:

   例如: 

    NSString * creatSql = @"CREATE TABLE IF NOT EXISTS StudentNum (idNum TEXT PRIMARY KEY,name TEXT);";

        char * err;

        /**

         第一个参数  DB对象

         第二个参数  sql语句

         第三个和第四个参数 回调函数和回调函数传递的参数

         第五个参数  是一个错误信息

         */

        if (sqlite3_exec(DB, [creatSql UTF8String], NULL, NULL, &err) != SQLITE_OK) {

            //失败

        }else{

            //创建表成功

        }

      在打开数据库、创建表失败等的情况下 也需要关闭数据库,也可以抛出错误信息:

            sqlite3_close(DB);

            NSAssert(NO, @"创建表失败");

     最后数据库操作完毕之后也要关闭数据库

 6.查询数据:

在数据库打开成功的情况下就可以进行查询了。

这条sql语句中的?是占位符。

   

    NSString * sql = @"SELECT idNum,name FROM StudentNum where idNum = ?";

    sqlite3_stmt * statement;//语句对象

    //预处理函数

    /*

     第一个参数:数据库对象

     第二个参数:sql语句

     第三个参数:执行语句的长度-1指全部长度

     第四个参数:语句对象

     第五个参数:没有执行的语句部分

     */

    if (sqlite3_prepare_v2(DB, [sql UTF8String], -1, &statement, NULL) == SQLITE_OK) {

        NSString * idNum = model.idNum;

        //绑定函数,绑定占位符要代替的内容

        /*

         第一个参数:语句对象

         第二个参数:数据开始执行的序号

         第三个参数:我们要绑定的值

         第四个参数:绑定的字符串的长度

         第五个参数:指针  NULL

         */

        sqlite3_bind_text(statement, 1, [idNum UTF8String], -1, NULL);

        //遍历去查询结果 返回值为SQLITE_ROW时代表查询出结果了,但是不能保证所有的数据都遍历了

        if (sqlite3_step(statement) == SQLITE_ROW) {

            //提取数据

            /*

             第一个参数:语句对象

             第二个参数:字段的索引

             */

            char * idNum = (char *)sqlite3_column_text(statement, 0)

            ;

            NSString * idNumStr = [[NSString alloc]initWithUTF8String:idNum];

            char * name = (char *)sqlite3_column_text(statement, 1);

            NSString * nameStr = [[NSString alloc]initWithUTF8String:name];

            studentModel * selectModel = [[studentModel alloc]init];

            selectModel.idNum = idNumStr;

            selectModel.name = nameStr;

            //查询到数据之后释放语句对象,并关闭数据库

            sqlite3_finalize(statement);

            sqlite3_close(DB);

            

        }

    }

相同,当打开数据库失败的时候也是要关闭数据库,抛出异常语句

增删改的顺序和上面查询的代码顺序是一样的,先打开数据库,然后进行预处理,然后绑定,然后遍历数据,然后提取数据,然后释放对象、关闭数据库。

posted @ 2016-11-10 21:52  微凉空间  Views(304)  Comments(0Edit  收藏  举报