前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >iOS开发之SQLite--C语言接口规范(五)——iOS开发使用SQLite实例

iOS开发之SQLite--C语言接口规范(五)——iOS开发使用SQLite实例

作者头像
lizelu
发布于 2018-01-11 09:06:42
发布于 2018-01-11 09:06:42
1.9K00
代码可运行
举报
文章被收录于专栏:青玉伏案青玉伏案
运行总次数:0
代码可运行

  本篇博客就使用前面操作SQLite的知识来实现如何去插入,删除和更新数据。然后再把操作SQlite数据库常用的方法进行一个封装。把常用方法进行封装后,把Cars数据库中的其中一个表的数据进行查询,并在UITableView上进行展示。因为本实例要对数据库的数据进行modify(修改)操作 ,在iOS系统上呢,为了安全起见,在Bundle中的数据库资源是不允许进行数据的插入修改和删除操作的。在之前的博客中我们只进行了查询操作,所以从Bundle加载数据库资源文件是可行的。

  如果对数据库进程insert, update, delete等操作,那么需要在打开数据库之前把Bundle中的数据库拷贝到沙盒中(每个App都有自己的沙盒,在没有越狱的机器上,App只可以访问自己的沙盒,这也是iOS比较安全的地方之一)。今天这篇博客会封装出一个操作SQLite数据库的工具类,并且调用这个工具类对数据库进行增删改查,实现一个小的实例。废话少说,直奔主题。

  一、数据库操作工具类

  为了操作数据库更为方便,对数据库操作:打开关闭数据库,无绑定值查询数据库,有绑定值查询数据库,插入数据,删除数据,更新数据等进行了简单的封装。当然有感兴趣的小伙伴可以继续完善,比如加上事务操作等。

  工具类对外接口介绍

  先来看一下封装的工具类对外的接口,然后介绍一下其使用方法。接口代码具体如下所示

代码语言:javascript
代码运行次数:0
运行
复制
 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中是无法去更改数据库中的数据的。下方是对外暴漏的接口。

代码语言:javascript
代码运行次数:0
运行
复制
/*******************************
 *功能:打开数据库
 *参数:databaseName -- 数据库名称
 *返回:数据库对象(sqlite3对象)
 *******************************/
+ (sqlite3 *) openDatabaseWithName: (NSString *)databaseName;

    该接口实现的具体方法如下,在关键代码出都加了注释,阅读代码时可以看一下注释,对于代码的东西就不做过多的赘述了。

代码语言:javascript
代码运行次数:0
运行
复制
 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对象进行一个关闭即可,具体代码如下:

代码语言:javascript
代码运行次数:0
运行
复制
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》.

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015-09-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
【IOS开发高级系列】CoreData专题
        Managed Object Model 是描述应用程序的数据模型,这个模型包含实体(Entity),特性(Property),读取请求(Fetch Request)等。(下文都使用英文术语。)
江中散人_Jun
2023/10/16
8800
【IOS开发高级系列】CoreData专题
iOS开发之SQLite--C语言接口规范(四) —— Result Values From A Query
  数据库的在上一篇博客中《SQLite之C语言接口规范(三)——Binding Values To Prepared Statements》用到了如何从查询结果中取出结果值。今天的博客就详细的介绍一下sqlite3_column_*()的方法。在SQLite数据库C语言接口中,从查询结果中取出不同类型的值需要不同的接口函数。   一. sqlite3_column_*()介绍     1.下图是sqlite3_column_*()所包含的方法,由下图容易的看出取出不同类型的值需要不同的接口函数。可以取出的
lizelu
2018/01/11
9510
iOS开发之SQLite--C语言接口规范(四) —— Result Values From A Query
iOS开发之SQLite-C语言接口规范(一)——Ready And Open Your SQLite
  为什么要搞一搞SQLite的C语言接口规范呢? 因为在做iOS开发中难免会遇到操作数据库的情况,你可以使用第三方的FMDB等,或者使用CoreData。但我们还是有必要去搞清楚如何去使用SQLite的C语言接口来操作SQLite数据库的。从今天开始就给大家结合实例详细的搞一搞SQLite的C语言接口。关于CoreData的东西请看之前的博客《IOS开发之表视图爱上CoreData》。   如果英文好的小伙伴呢,你可以不听我啰嗦,直接官网走起:http://www.sqlite.org 上面的东西是应有尽
lizelu
2018/01/11
1.3K0
iOS开发之SQLite-C语言接口规范(一)——Ready And Open Your SQLite
iOS开发之SQLite--C语言接口规范(三)——Binding Values To Prepared Statements
  在前面的博客中已经介绍了如何连接SQLite数据库,并且简单的查询和遍历结果集。在前面用到了sqlite3_stmt *stmt,也就是预编译后的SQL语句。在本篇博客中会了解一下sqlite3_stmt,然后了解一下变量的绑定。变量绑定,简单的说就是往预编译后的SQL语句中传入相应的值。   一. sqlite3_stmt 的生命周期   这个对象的实例代表着一个被编译成二进制的SQL语句。每个SQL语句都必须经过预编译转换成sqlite3_stmt才能被执行。在iOS开发中,Application或
lizelu
2018/01/11
1.3K0
iOS开发之SQLite--C语言接口规范(三)——Binding Values To Prepared Statements
学习SQLite之路(五) C/C++ SQLite开发实例
  介绍一种乌班图中使用sqlite的用法,非常简单,下面的例子是在乌班图12.04中实现的: 1,先安装两个东西: sudo apt-get install sqlite sqlite3 sudo apt-get install libsqlite3-dev  // 不然可能会报 没有头文件 sqlite3.h 2,C/C++接口:一般用到下面这三个,详情请参考sqlite官方文档。 (1)sqlite3_open(const char *filename, sqlite3 **ppDb):     打开
xcywt
2018/01/11
1.9K0
学习SQLite之路(五) C/C++ SQLite开发实例
iOS学习——iOS常用的存储方式
不管是在iOS还是Android开发过程中,我们都经常性地需要存储一些状态和数据,比如用户对于App的相关设置、需要在本地缓存的数据等等。根据要存储的的数据的大小、存储性质以及存储类型,在iOS和Android中哪个都有多种存储方式。其中,iOS中的存储方式主要包括以下六类: plist文件(属性列表) preference(偏好设置) NSKeyedArchiver(归档) SQLite 3 CoreData 手动存放沙盒 一、沙盒机制 在研究存储方式之前,我们有必要先研究下这些文件会存储到什么地方去
mukekeheart
2018/03/01
3.1K0
iOS学习——iOS常用的存储方式
iOS---数据离线缓存
离线缓存 为了用户的体验,不需要每次打开App都加载新数据,或者重新请求数据,因此需要把每次浏览的数据保存起来,当下次打开软件时,首先从沙盒中加载数据;或者当软件未联网时,也只能从沙盒中加载旧数据。 离线数据的方法选择 1.plist文件 2.Document路径 3.数据库 由于保存的是大批量数据,且会不停的刷新新数据,因此应该选择数据库来存储。 离线缓存的思路 当第一次打开应用程序时,把界面加载好的数据保存到沙盒中 当下一次进入应用程序时,首先从沙盒中找 如果没有网络,直接加载上次保存的数据,或者没有
用户1941540
2018/05/11
1.2K0
【IOS开发基础系列 整理】IOS沙盒机制专题
http://blog.csdn.net/totogo2010/article/details/7669837
江中散人_Jun
2023/10/16
4200
【IOS开发基础系列 整理】IOS沙盒机制专题
【IOS开发基础系列】数据持久化专题
iOS中可以有四种持久化数据的方式: 属性列表、对象归档、SQLite3和Core Data。
江中散人_Jun
2023/10/16
4120
【IOS开发基础系列】数据持久化专题
iOS CoreData (一) 增删改查
选择Arguments,在下面的ArgumentsPassed On Launch中添加下面两个选项,如图:
且行且珍惜_iOS
2018/05/22
1.3K0
学习iPhone开发中 sqlite3的
    由于我主要负责我们小组项目数据库模块的部分所以这几天都一直在研究在iphone中最为常用的一个简单数据库sqlite,自己也搜集很多资料,因此在这里总结一下这几天的学习成果:
py3study
2020/01/08
1K0
iOS开发——FMDB的使用
今天决定给手上的项目加上一个数据库,用来进行数据持久化操作,关于在iOS端的数据持久化方式的差异,这里也就不再赘述,相信如果真实使用并且去感受过的人,有自己的评判标准。
Originalee
2018/08/30
8030
iOS使用sqlite可以实现简单的收藏夹功能
在这个类里首先导入一个头文件和你建好的model类 (实现收藏本质是存model类)
用户7108768
2021/09/22
2940
玩转SQLite-11:C语言高效API之sqlite3_prepare系列函数
SQLite是一个跨平台的轻量级数据库,支持C/C++开发,可用于嵌入式中,关于C/C++使用SQLite的简单实例,之前这篇文章,已经介绍过一种简单的使用方式。本篇来介绍另一种更加高效的调用方式。
xxpcb
2022/12/29
1.8K0
老司机出品——数据持久化之基于FMDB的ORM数据库设计
这次呢,我们来说说iOS中数据持久化的几种方案。说到iOS中的数据存储,无非有4中方式:
老司机Wicky
2018/08/22
1.2K0
老司机出品——数据持久化之基于FMDB的ORM数据库设计
ios在SQLite3基本操作
首先是设置项目文件。在项目中加入iPhone版的sqlite3的数据库的开发包。在项目下的Frameworks点击右键。然后选择libsqlite3.0.dylib文件。
全栈程序员站长
2022/07/05
7820
iOS开发--常用的数据存储方式
1、XML属性列表(plist)归档 2、preference(偏好设置) 3、NSKeyedArchiver归档(NSCoding) 4、SQLite3 5、Core Data
孙寅
2020/06/02
9130
【Android 应用开发】Android 数据存储 之 SQLite数据库详解
转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19028665
韩曙亮
2023/03/27
2.7K0
【Android 应用开发】Android 数据存储 之 SQLite数据库详解
使用iOS原生sqlite3框架对sqlite数据库进行操作
      sqlite数据库是一种小型数据库,由于其小巧与简洁,在移动开发领域应用深广,sqlite数据库有一套完备的sqlite语句进行管理操作,一些常用的语句和可视化的开发工具在上篇博客中有介绍,地址如下:
珲少
2018/08/15
2.3K0
使用iOS原生sqlite3框架对sqlite数据库进行操作
iOS本地数据存储
数据存储本质就是运行时的对象保存在文件、数据库中。数据存储可以分为两步:首先是将对象转换成二进制数据,这一步也叫序列化;相反,将二进制数据转换成对象则称为反序列化;然后是考虑二进制数据如何保存和读取。
落影
2019/07/15
3.1K0
iOS本地数据存储
相关推荐
【IOS开发高级系列】CoreData专题
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档