文档章节

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

秦无炎
 秦无炎
发布于 2016/07/21 11:36
字数 718
阅读 5
收藏 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
博文 123
码字总数 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.9K
35
手撸一个数据库框架 part2 - 增删改查

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

JakePrim
03/24
0
0
iOS SQLite3轻量开发框架

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

IamOkay
2016/04/14
192
3
iOS开发之FMDB的是本使用

FMDB是将sqlite3的语法封装成OC的语法 基于sqlite3的 使用的步骤: 1.创建打开一个数据库 2.向数据库里添加一个表 3.数据的增删改查 首先这里要使用一个第三方库fmdb,导入这个之后,操作如下...

鹿微微鹿
2016/05/04
38
0

没有更多内容

加载失败,请刷新页面

加载更多

Kafka+Flink 实现准实时异常检测系统

1.背景介绍 异常检测可以定义为“基于行动者(人或机器)的行为是否正常作出决策”,这项技术可以应用于非常多的行业中,比如金融场景中做交易检测、贷款检测;工业场景中做生产线预警;安防...

架构师springboot
10分钟前
0
0
DecimalFormat 类基本使用

/* * DecimalFormat 类主要靠 # 和 0 两种占位符号来指定数字长度 * 0 表示如果位数不足则以 0 填充 * # 表示只要有可能就把数字拉上这个位置 * */ public static void main(String[] args){...

嘴角轻扬30
27分钟前
1
0
This APT has Super Cow Powers.

在Debian/Ubuntu上,apt包管理器内嵌着一个彩蛋. 如果你在命令行界面输入 apt help 在最后一行能找到This APT has Super Cow Powers. 说明该apt具有超级牛力 牛力是个什么梗? 则说明你的系统...

taadis
45分钟前
1
0
起薪2万的爬虫工程师,Python需要学到什么程度才可以就业?

爬虫工程师的的薪资为20K起,当然,因为大数据,薪资也将一路上扬。那么,Python需要学到什么程度呢?今天我们来看看3位前辈的回答。 1、前段时间快要毕业,而我又不想找自己的老本行Java开发...

糖宝lsh
53分钟前
6
0
携手开发者共建云生态 首届腾讯云+社区开发者大会在京举办

本文由云+社区发表 北京时间12月15日,由腾讯云主办,极客邦科技、微信、腾讯TEG协办的首届腾讯云+社区开发者大会在北京朝阳悠唐皇冠假日酒店举办。在会上,腾讯云发布了重磅产品开发者平台以...

腾讯云加社区
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部