iOS 基于FMDB简单的查询操作

转载自: https://blog.csdn.net/rpf2014/article/details/53116906

上一篇文章介绍了FMDB的安装增删改查等的操作

这篇文章主要是数据查询的筛选和常用的数据库统计函数,便于以后的查询和学习.

查询函数主要分为两大类

第一大类就是数据的筛选 是基于数据表的筛选

数据源

[objc]  view plain  copy
  1. -(void)dataConfig{  
  2.     _dataArr = [[NSMutableArray alloc] init];  
  3.       
  4.     Worker *w1 = [[Worker alloc] init];  
  5.     w1.workId = @"2";  
  6.     w1.name = @"小明1";  
  7.     w1.age = 12;  
  8.     Worker *w2 = [[Worker alloc] init];  
  9.     w2.workId = @"1";  
  10.     w2.name = @"小明2";  
  11.     w2.age = 13;  
  12.     Worker *w3 = [[Worker alloc] init];  
  13.     w3.workId = @"3";  
  14.     w3.name = @"小李";  
  15.     w3.age = 14;  
  16.     Worker *w4 = [[Worker alloc] init];  
  17.     w4.workId = @"4";  
  18.     w4.name = @"小李";  
  19.     w4.age = 15;  
  20.     [_dataArr addObject:w1];  
  21.     [_dataArr addObject:w2];  
  22.     [_dataArr addObject:w3];  
  23.     [_dataArr addObject:w4];  
  24.       
  25. }  
先封装一下数据的统计

[objc]  view plain  copy
  1. -(NSMutableArray *)getReArrFromSql:(NSString *)sql{  
  2.     FMResultSet *rs = [_database executeQuery:sql];  
  3.     NSMutableArray *arr = [[NSMutableArray alloc] init];  
  4.     while ([rs next]) {  
  5.         Worker *model = [[Worker alloc] init];  
  6.         model.workId = [rs stringForColumn:@"workId"];  
  7.         model.name = [rs stringForColumn:@"name"];  
  8.         model.age = [rs intForColumn:@"age"];  
  9.         [arr addObject:model];  
  10.     }  
  11.     return arr;  
  12. }  

数据的升序和降序

[objc]  view plain  copy
  1. //order by  
  2. //1 排序  
  3. //asc 默认 升序  
  4. //desc 降序  
  5. -(NSMutableArray *)getAllDataOrderBy:(NSString *)type{  
  6.     NSString *sql = [NSString stringWithFormat:@"select * from workTable order by workId %@",type];  
  7.     return [self getReArrFromSql:sql];  
  8. }  
去重

[objc]  view plain  copy
  1. //distinct  
  2. //1 只能放在最前面  
  3. //2 只能作用于一列  
  4. -(NSMutableArray *)getAllDataDistinct{  
  5.     NSString *sql = [NSString stringWithFormat:@"select distinct name from workTable"];  
  6.     return [self getReArrFromSql:sql];  
  7. }  

[objc]  view plain  copy
  1. //and就是并的作用  
  2. -(NSMutableArray *)getAllDataAnd{  
  3.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where workId = 1 and name = '小张'"];  
  4.     return [self getReArrFromSql:sql];  
  5. }  

[objc]  view plain  copy
  1. //or就是或的作用  
  2. -(NSMutableArray *)getAllDataOr{  
  3.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where workId = 1 or name = '小李'"];  
  4.     return [self getReArrFromSql:sql];  
  5. }  
like 模糊查询
[objc]  view plain  copy
  1. //like  
  2. //结尾是李的所有数据  
  3. -(NSMutableArray *)getAllDataLike1{  
  4.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where name like '%%李'"];  
  5.     return [self getReArrFromSql:sql];  
  6. }  
[objc]  view plain  copy
  1. //开头是小的所有数据  
  2. -(NSMutableArray *)getAllDataLike2{  
  3.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where name like '小%%'"];  
  4.     return [self getReArrFromSql:sql];  
  5. }  
[objc]  view plain  copy
  1. //中间是明的所有数据  
  2. -(NSMutableArray *)getAllDataLike3{  
  3.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where name like '%%明%%'"];  
  4.     return [self getReArrFromSql:sql];  
  5. }  
[objc]  view plain  copy
  1. //不包含明的所有数据  
  2. -(NSMutableArray *)getAllDataLike4{  
  3.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where name not like '%%明%%'"];  
  4.     return [self getReArrFromSql:sql];  
  5. }  
in 相当于集合
[objc]  view plain  copy
  1. //in 相当于集合  
  2. -(NSMutableArray *)getAllDataIn{  
  3.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where name in ('小明1','小李')"];  
  4.     return [self getReArrFromSql:sql];  
  5. }  
between and 闭区间
[objc]  view plain  copy
  1. //between sqlite里面的between都是闭区间  
  2. -(NSMutableArray *)getAllDataBetween{  
  3.     NSString *sql = [NSString stringWithFormat:@"select * from workTable where workId between 1 and 3"];  
  4.     return [self getReArrFromSql:sql];  
  5. }  
第二大类是数据的统计,比如数据量,某个字段的平均值
分组并筛选

[objc]  view plain  copy
  1. //group by 筛选结果的计算  
  2. //having 对group by 结果的进一步筛选  
  3. -(NSMutableArray *)getAllDataGroupBy{  
  4.     NSString *sql = [NSString stringWithFormat:@"select name,sum(age) s from workTable group by name having s>15"];  
  5.     NSMutableArray *arr = [[NSMutableArray alloc] init];  
  6.     FMResultSet *rs = [_database executeQuery:sql];  
  7.     while ([rs next]) {  
  8.         Worker *model = [[Worker alloc] init];  
  9.         model.name = [rs stringForColumn:@"name"];  
  10.         model.age = [rs intForColumn:@"s"];  
  11.         [arr addObject:model];  
  12.     }  
  13.     return arr;  
  14. }  
最小值

[objc]  view plain  copy
  1. //min 最小值  
  2. -(NSInteger)getAllDataMin{  
  3.     NSString *sql = [NSString stringWithFormat:@"select min(age) minAge from workTable"];  
  4.     NSMutableArray *arr = [[NSMutableArray alloc] init];  
  5.     FMResultSet *rs = [_database executeQuery:sql];  
  6.     while ([rs next]) {  
  7.         Worker *model = [[Worker alloc] init];  
  8.         model.statistic = [rs intForColumn:@"minAge"];  
  9.         [arr addObject:model];  
  10.     }  
  11.     Worker *model = [arr firstObject];  
  12.     return model.statistic;  
  13. }  

最大值

[objc]  view plain  copy
  1. //max 最大值  
  2. -(NSInteger)getAllDataMax{  
  3.     NSString *sql = [NSString stringWithFormat:@"select max(age) maxAge from workTable"];  
  4.     NSMutableArray *arr = [[NSMutableArray alloc] init];  
  5.     FMResultSet *rs = [_database executeQuery:sql];  
  6.     while ([rs next]) {  
  7.         Worker *model = [[Worker alloc] init];  
  8.         model.statistic = [rs intForColumn:@"maxAge"];  
  9.         [arr addObject:model];  
  10.     }  
  11.     Worker *model = [arr firstObject];  
  12.     return model.statistic;  
  13. }  

数据之和

[objc]  view plain  copy
  1. //sum 数据之和  
  2. -(NSInteger)getAllDataSum{  
  3.     NSString *sql = [NSString stringWithFormat:@"select sum(age) sumAge from workTable"];  
  4.     NSMutableArray *arr = [[NSMutableArray alloc] init];  
  5.     FMResultSet *rs = [_database executeQuery:sql];  
  6.     while ([rs next]) {  
  7.         Worker *model = [[Worker alloc] init];  
  8.         model.statistic = [rs intForColumn:@"sumAge"];  
  9.         [arr addObject:model];  
  10.     }  
  11.     Worker *model = [arr firstObject];  
  12.     return model.statistic;  
  13. }  

数据平均值

[objc]  view plain  copy
  1. //avg 数据的平均值  
  2. -(NSInteger)getAllDataAvg{  
  3.     NSString *sql = [NSString stringWithFormat:@"select avg(age) avgAge from workTable"];  
  4.     NSMutableArray *arr = [[NSMutableArray alloc] init];  
  5.     FMResultSet *rs = [_database executeQuery:sql];  
  6.     while ([rs next]) {  
  7.         Worker *model = [[Worker alloc] init];  
  8.         model.statistic = [rs intForColumn:@"avgAge"];  
  9.         [arr addObject:model];  
  10.     }  
  11.     Worker *model = [arr firstObject];  
  12.     return model.statistic;  
  13. }  

数据量

[objc]  view plain  copy
  1. //count 表中的数据量  
  2. -(NSInteger)getAllDataCount{  
  3.     NSString *sql = [NSString stringWithFormat:@"select count(*) count from workTable"];  
  4.     NSMutableArray *arr = [[NSMutableArray alloc] init];  
  5.     FMResultSet *rs = [_database executeQuery:sql];  
  6.     while ([rs next]) {  
  7.         Worker *model = [[Worker alloc] init];  
  8.         model.statistic = [rs intForColumn:@"count"];  
  9.         [arr addObject:model];  
  10.     }  
  11.     Worker *model = [arr firstObject];  
  12.     return model.statistic;  
  13. }  

以上就是简单的数据库查询和统计

Demo http://download.csdn.net/detail/rpf2014/9689776



你可能感兴趣的:(iOS 基于FMDB简单的查询操作)