文档章节

基于SQLite3轻量级封装,一行代码实现增删改查

秦无炎
 秦无炎
发布于 2016/07/21 11:36
字数 718
阅读 4
收藏 1
 

D61084AE-36DE-4516-802E-1E4619B637DF.png

 

最近几天一直在看关于数据库的资料,写了各种sql语句,已经在崩溃的边缘,为了下次不再写重复的语句,更为了偷懒...花了几天时间基于SQLite3封装了一下,常用的功能一行代码就可以实现,内部使用runtime获取属性列表,再利用KVC完成赋值,不多说,直接上代码,

 

下面是提供的接口

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

/// 获取全局数据库单例

+ (instancetype)sharedManager;

/**

 *  打开数据库

 *

 *  @return 成功/失败

 */

- (BOOL)openDatabase;

/**

 *  根据类名创建表格,默认主键为t_default_id

 *

 *  @param className  类名t_default_id

 */

- (BOOL)creatTableWithClassName:(id)className;

 

#pragma mark -

#pragma mark - =============== 插入数据 ===============

/**

 *  插入数据

 *  该方法会将模型对象插入到对象类型所对应的表格中 

 *  @param object 模型对象

 */

- (void)insertDataFromObject:(id)object;

 

#pragma mark -

#pragma mark - =============== 查询数据 ===============

/**

 *  获取表格中所有数据,

 */

- (NSArray *)selecteDataWithClass:(id)className;

 

/**

 *  获取表格中数据行数

 */

- (NSInteger)getTotalRowsFormClass:(id)className;

 

/**

 *  获取表格中第n条数据

 */

- (id)selecteFormClass:(id)className index:(NSInteger)index;

 

/**

 *  单条件查询

 *

 *  @param obj   类名

 *  @param key   属性名 例 @"name"

 *  @param opt   符号 例 @"=" > < 

 *  @param value 值 例 @"zhangsan"

 *

 *  @return 查询结果

 */

- (NSArray *)selectObject:(Class)className key:(id)key operate:(NSString *)operate value:(id)value;

 

/**

 *  自定义语句查询

 *

 *  @param sqlString 自定义的sql语句

 *  @param className 类名

 *

 *  @return 查询结果

 */

- (NSArray *)selecteDataWithSqlString:(NSString *)sqlString class:(id)className;

 

/**

 *  数据库模糊查询(单条件)

 *

 *  @param obj          类

 *  @param propertyName 属性名也是字段名

 *  @param type         模糊查询的位置类型

 *  @param content      查询的字符串

 *

 *  @return 查询内容

 */

- (NSArray *)selectObject:(Class)className propertyName:(NSString *)propertyName type:(GKDatabaseSelectLocation)type content:(NSString *)content;

 

#pragma mark -

#pragma mark - =============== 更新数据 ===============

/**

 *  数据更新

 *

 *  @param obj             类名

 *  @param oldValues   要更新的内容 例 @【@"name=lisi"】

 *  @param conditionType   条件类型 例 OR 或者 AND

 *  @param newValues 更新条件 例 @【@"id=5",@"name=zhangsan"】

 */

- (BOOL) updateObject:(Class)className oldValues:(NSArray *)oldValues conditionType:(QueryType)conditionType newValues:(NSArray *)newValues;

 

#pragma mark -

#pragma mark - =============== 删除数据 ===============

/**

 *  删除数据

 *

 *  @param className 类名

 *  @param string    删除语句,字符串需要加上单引号 例@"name = 'Chris'" / @"id = 1234" / @"integer > 1234";

 *

 *  @return 删除结果

 */

- (BOOL)deleteObject:(Class)className withString:(NSString *)string;

 

/**

 *  清空数据库某表格的内容

 *

 *  @param className 类名

 *

 *  @return 清空结果

 */

- (BOOL)clearTableWithName:(id)className;

 

/**

 *  删除数据库表格

 *

 *  @param className 类名

 *

 *  @return 删除结果

 */

- (BOOL)deleteTableWithTableName:(id)className;

具体使用请看Demo:https://github.com/ChrisCaixx/GKDatabase

源码中给出了详细的注释,如有需要请移步:https://github.com/ChrisCaixx/GKDatabase 如觉得好用,

本文转载自:

共有 人打赏支持
秦无炎
粉丝 4
博文 122
码字总数 5319
作品 0
朝阳
程序员
Fly的狐狸/jmoney

财务管理jfinal+beetl 本网站后台基于Jfinal开发,前台模板使用beetl,数据库为Mysql。 演示地址:http://www.jflyfox.com/jmoney 平台部署说明 下载jmoney项目:配置数据库文件/jmoney/src...

Fly的狐狸
2014/06/05
0
0
金钱管理软件 jfinal money 4.0 更简单了

更新说明: 由于许多人下载代码后,会反映CRUD封装可读性太差,这次对前台进行了全面重构。 把CRUD封装改为代码自动生成,这样对简单的增删改查仍然可以通过配置,而不写任何前台代码,并且项...

Fly的狐狸
2015/01/08
4.8K
35
手撸一个数据库框架 part2 - 增删改查

在上一篇目中,讲解了如何自动建表,代码. 本期来实现增删改查,这里现实最简单的增删改查,主要讲解实现思想,复杂的会在后续文章中讲解。 准备工作 1.首先在BaseDao init 方法,在建表时,...

JakePrim
03/24
0
0
(原理篇)基于SQLite3轻量级封装,一行代码实现增删改查

最近写的项目中有用到数据库,写了不少蛋疼的sql语句,每次都是好几行代码,而且每次都是重复的没有一点技术含量的代码,虽然也有不少基于sqlite的封装,不过用起来还是感觉不够面向对象! 为了不再...

秦无炎
2016/07/25
22
0
iOS SQLite3轻量开发框架

最近做一款app,使用到了Sqlite3数据库,ios上的sqlite都是可移植的c语言代码,但是使用起来不像java或者php那么方便,打算尝试一下realm,但是由于项目代码要求支持SQL,因此只能使用SQLite3...

IamOkay
2016/04/14
192
3

没有更多内容

加载失败,请刷新页面

加载更多

你为什么在Redis里读到了本应过期的数据

一个事故的故事 晚上睡的正香突然被电话吵醒,对面是开发焦急的声音:我们的程序在访问redis的时候读到了本应过期的key导致整个业务逻辑出了问题,需要马上解决。 看到这里你可能会想:这是不...

IT--小哥
45分钟前
0
0
祝大家节日快乐,阖家幸福! centos GnuTLS 漏洞

yum update -y gnutls 修复了GnuTLS 漏洞。更新到最新 gnutls.x86_64 0:2.12.23-22.el6 版本

yizhichao
昨天
3
0
Scrapy 1.5.0之选择器

构造选择器 Scrapy选择器是通过文本(Text)或 TextResponse 对象构造的 Selector 类的实例。 它根据输入类型自动选择最佳的解析规则(XML vs HTML): >>> from scrapy.selector import Sele...

Eappo_Geng
昨天
2
0
Windows下Git多账号配置,同一电脑多个ssh-key的管理

Windows下Git多账号配置,同一电脑多个ssh-key的管理   这一篇文章是对上一篇文章《Git-TortoiseGit完整配置流程》的拓展,所以需要对上一篇文章有所了解,当然直接往下看也可以,其中也有...

morpheusWB
昨天
3
0
中秋快乐!!!

HiBlock
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部