sqliteiOS开发之SQLite–C语言接口规范(五)——iOS开发应用SQLite实例

  本篇博客就动用前面操作SQLite的学问来促成怎么着去插入,删除和革新数据。然后再把操作SQlite数据库常用的格局开展一个打包。把常用方法举办包装后,把Cars数据库中的其中一个表的数额开展询问,并在UITableView上进展显示。因为本实例要对数据库的多寡开展modify(修改)操作
,在iOS系统上吧,为了安全起见,在Bundle中的数据库资源是不容许进行多少的插入修改和删除操作的。在头里的博客中我们只进行了查询操作,所以从Bundle加载数据库资源文件是立竿见影的。

  如果对数据库进度insert, update,
delete等操作,那么须求在开拓数据库从前把Bundle中的数据库拷贝到沙盒中(每个App都有协调的沙盒,在一直不越狱的机器上,App只好访问自己的沙盒,那也是iOS相比较安全的地点之一)。先天那篇博客会封装出一个操作SQLite数据库的工具类,并且调用这么些工具类对数据库举办增删改查,完毕一个小的实例。废话少说,直奔主旨。

sqlite,  一、数据库操作工具类

  为了操作数据库更为有利,对数据库操作:打开关闭数据库,无绑定值查询数据库,有绑定值查询数据库,插入数据,删除数据,更新数据等开展了简约的卷入。当然有感兴趣的同伙可以三番五次完善,比如加上作业操作等。

  工具类对外接口介绍

  先来看一下包装的工具类对外的接口,然后介绍一下其利用情势。接口代码具体如下所示

 1 //
 2 //  OperationSqliteTools.h
 3 //  SettingBundleDemo
 4 //
 5 //  Created by Mr.LuDashi on 15/8/31.
 6 //  Copyright (c) 2015年 zeluli. All rights reserved.
 7 //
 8 
 9 #import <Foundation/Foundation.h>
10 #import <sqlite3.h>
11 
12 @interface OperationSqliteTools : NSObject
13 
14 /*******************************
15  *功能:打开数据库
16  *参数:databaseName -- 数据库名称
17  *返回:数据库对象(sqlite3对象)
18  *******************************/
19 + (sqlite3 *) openDatabaseWithName: (NSString *)databaseName;
20 
21 /*******************************
22  *功能:关闭数据库
23  *参数:database -- sqlite3 对象
24  *返回:空
25  *******************************/
26 + (void) closeDatabaseWithName: (sqlite3 *)database;
27 
28 /*******************************
29  *功能:查询数据,无绑定变量
30  *参数:database -- sqlite3 对象, SQL:要执行的SQL查询语句
31  *返回:封装成数组的查询数据
32  *******************************/
33 + (NSArray *) queryInfoWithDataBase: (sqlite3 *) database
34                             WithSQL: (NSString *) SQL;
35 
36 
37 /*******************************
38  *功能:查询数据,有绑定变量
39  *参数:database -- sqlite3 对象, SQL:要执行的SQL查询语句,parameter:绑定变量的值
40  *返回:封装成数组的查询数据
41  *******************************/
42 + (NSArray *) queryInfoWithDataBase: (sqlite3 *) database
43                             WithSQL: (NSString *) SQL
44                       WithParameter: (NSArray *)parameter;
45 
46 
47 /*******************************
48  *功能:插入数据
49  *参数:database -- sqlite3 对象, SQL:要执行的SQL插入语句,parameter:绑定变量的值
50  *返回:插入结果,YES:插入成功, NO:插入失败
51  *******************************/
52 + (BOOL) insertDataWithDataBase: (sqlite3 *) database
53                         WithSQL: (NSString *) SQL
54                   WithParameter: (NSArray *)parameter;
55 
56 /*******************************
57  *功能:更新数据
58  *参数:database -- sqlite3 对象, SQL:要执行的SQL插入语句,parameter:绑定变量的值
59  *返回:插入结果,YES:更新成功, NO:更新失败
60  *******************************/
61 + (BOOL) updateDataWithDataBase: (sqlite3 *) database
62                         WithSQL: (NSString *) SQL
63                   WithParameter: (NSArray *)parameter;
64 
65 
66 /*******************************
67  *功能:删除数据
68  *参数:database -- sqlite3 对象, SQL:要执行的SQL插入语句,parameter:绑定变量的值
69  *返回:插入结果,YES:删除成功, NO:删除失败
70  *******************************/
71 + (BOOL) deleteDataWithDataBase: (sqlite3 *) database
72                         WithSQL: (NSString *) SQL
73                   WithParameter: (NSArray *)parameter;
74 
75 /*******************************
76  *功能:打印出查询后的结果
77  *参数:array -- 结果数组
78  *返回:空
79  *******************************/
80 + (void) displayResultWithArray: (NSArray *) array;
81 
82 
83 @end

  二、
接口的有血有肉介绍

    1、打开数据库

     上面的接口是开拓数据库成效,把数据库的名字传入如(Cars.sqlite),再次来到的是一个sqlite3的靶子,你能够经过那一个目的来对打开的数据库举办操作。在这一个方式中,先去沙盒中查看是还是不是有该数据库,假如有就直接打开。借使没有就从Bundle中把数据库资源复制到沙盒中,然后再从沙盒中打开。你要知道在Bundle中是无力回天去改变数据库中的数据的。下方是对外暴漏的接口。

/*******************************
 *功能:打开数据库
 *参数:databaseName -- 数据库名称
 *返回:数据库对象(sqlite3对象)
 *******************************/
+ (sqlite3 *) openDatabaseWithName: (NSString *)databaseName;

    

    该接口达成的具体方法如下,在重点代码出都加了诠释,阅读代码时方可看一下评释,对于代码的事物就不做过多的废话了。

 1 /*******************************
 2  *功能:打开数据库
 3  *参数:databaseName -- 数据库名称
 4  *返回:数据库对象(sqlite3对象)
 5  *******************************/
 6 + (sqlite3 *) openDatabaseWithName: (NSString *)databaseName{
 7     
 8     //将数据库文件复制到沙盒中
 9     NSFileManager *fileManager = [NSFileManager defaultManager];
10     
11     //获取沙盒路径
12     NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
13     
14     NSString *documentDirectory = paths[0];
15     
16     //拼接出数据库文件在沙盒中的路径
17     NSString *sqlPath = [documentDirectory stringByAppendingPathComponent:databaseName];
18     
19     //判断沙盒中是否已经存在我们要打开的数据库文件
20     BOOL success = [fileManager fileExistsAtPath:sqlPath];
21     
22     //不存在的情况,会从Bundle中把资源复制过去
23     if (!success) {
24         NSString *defautlDBPath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:databaseName];
25         
26         NSError *error = nil;
27         
28         success = [fileManager copyItemAtPath:defautlDBPath toPath:sqlPath error:&error];
29         
30         if (!success) {
31             NSLog(@"%@", [error localizedDescription]);
32         }
33     }
34     //把路径转成C字符串
35     const char * filePath = [sqlPath UTF8String];
36     
37     //声明sqlite3对象
38     sqlite3 * database = nil;
39     
40     //打开数据库
41     int result = sqlite3_open_v2(filePath, &database, SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE, NULL);
42     
43     //成功打开
44     if (result == SQLITE_OK) {
45         return database;
46     }
47     
48     return nil;
49 }

 

    2.闭馆数据库

    关闭数据库就相比简单了,直接把传播的sqlite3对象进行一个关门即可,具体代码如下:

1 /*******************************
2  *功能:关闭数据库
3  *参数:database -- sqlite3 对象
4  *返回:空
5  *******************************/
6 + (void) closeDatabaseWithName: (sqlite3 *)database{
7     sqlite3_close(database);
8 }

 

   3.
代码好多,博客篇幅有限,就不一一的去往上粘贴代码了,具体代码已毕回在GitHub上进展分享,gitHub连接请看本博客的末尾处,在代码中也是在主要部分添加了对应的笺注。

 

  三、实例已毕

  调用上述不难包装的不二法门完成实例,对Cars.sqlite数据中内部一个表举行操作。先读取数据库中的数据,在TableView上展开加载,然后可以对数码举办添加和删除操作,更新操作就不做示范了。在插入操作中有如果有那条数据就进展Replace,那变相是一个update操作。

  下方是Demo的运转效果,为了反映数据插入和删除的转变意义,给大家的Cell添加了一个动画片效果,便于寓目数据的更动。这一个Demo也会在Github上拓展分享,你可以友善运行去看一下效果。下方是动态的周转效果。为了简化操作,点击加号会有预先设定好的数目开展插队(当然你可以把用户输入的数额举行一个增进),删除的话就是TableView自带的效应删除。

  下方Demo的兑现并从未什么样困难之处,就是对TableView的简短操作,若是您感兴趣的话,可以从Github上拓展clone,然后举办伸张,添加上搜索,更新等职能。关于CoreData的操作就要看从前的博客《iOS开发之表视图爱上CoreData》.

sqlite 1

 

    gitHub分享地址:https://github.com/lizelu/SQLiteResource

网站地图xml地图