AFN请求FMDB数据库

创建一个model存放数据

.h
//数据库必须得有一个主键id
@property(nonatomic,assign)NSInteger classid;

@property(nonatomic,copy)NSString *title;//标题

@property(nonatomic,copy)NSString *url;//跳转url

.m里面
//找不到key值放空
-(void)setValue:(id)value forUndefinedKey:(NSString *)key{
    
}

在创建一个SqlData存放数据库方法

引入model头文件

//单利方法
+(instancetype)initData;
//初始化数据库
-(void)initSql;
//初始化表格
-(void)initTable;
//添加数据
-(void)addData:(id)data;
//删除数据
-(void)deleteData:(NSInteger )theid;
//查询数据
-(id)getDataArray;
//关闭数据库
-(void)closeSql;

.m里实现方法

引入model头文件
引入第三方FMDB头文件

定义两个宏
static SqlData *sql;
static FMDatabase *db;

实现方法
+ (instancetype)initData{
    if (!sql) {
        sql = [[SqlData alloc]init];
    }
    return sql;
}

- (void)initSql{
    //创建路径
    NSString *str = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)firstObject];
    //拼接路径
    NSString *file = [str stringByAppendingString:@"movies.db"];
    //创建数据库
    db = [[FMDatabase alloc]initWithPath:file];
    if ([db open]) {
        NSLog(@"数据库打开");
        [self initTable];
    }else{
        NSLog(@"数据库打开失败");
    }
}

- (void)initTable{
    //初始化数据库表格的格式:create table if not exists 表名(主键id integer primary key,所有的数据类型);
    //创建表格
    [db executeUpdate:@"create table if not exists DataModel(classid integer primary key,title text,url text)"];
    //关闭数据库
    [db close];
}

- (void)addData:(DataModel *)Model{
    //添加数据库
    //添加数据的sql语句:insert into 表名 values(null,?,?);
    //先判断是否打开
    if ([db open]) {
        [db executeUpdate:[NSString stringWithFormat:@"insert into DataModel values(null,'%@','%@')",Model.title,Model.url]];
        NSLog(@"插入成功");
        NSLog(@"model ------------- %@",Model);
    }else{
        NSLog(@"打开失败");
    }
    [db close];
}

- (void)deleteData:(NSInteger)theid{
    //sql 语句: delete from 表名 where 表名的主键id = ?
    if ([db open]) {
        
        [db executeUpdate:[NSString stringWithFormat:@"delete from DataModel where classid = '%ld'",theid]];
        NSLog(@"删除成功");
    }else{
        NSLog(@"删除数据失败");
    }
    //关闭数据库
    [db close];
}

- (NSArray *)getDataArray{
    //创建数据
    NSMutableArray *array = [NSMutableArray new];
    //集合
    FMResultSet *Set = [FMResultSet new];
    
    if ([db open]) {
        //sql 语句格式:select *from 表名
        Set = [db executeQuery:@"select * from DataModel"];
        //判断有没有东西
        while ([Set next]) {
            DataModel *dataM = [DataModel new];
            dataM.title = [Set stringForColumn:@"title"];
            dataM.url = [Set stringForColumn:@"url"];
            dataM.classid = [Set intForColumn:@"classid"];
            NSLog(@"dataM===============%@",dataM);
            [array addObject:dataM];
            NSLog(@"查询成功");
        }
    }else{
        NSLog(@"查询失败");
    }
    [db close];
    
    return array;
    
}

- (void)closeSql{
    
}

主界面搭建一个表格

//请求数据
    AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
    manager.responseSerializer = [AFHTTPResponseSerializer serializer];
    [manager GET:@"http://c.m.163.com/nc/article/list/T1348648517839/0-20.html" parameters:nil progress:^(NSProgress * _Nonnull downloadProgress) {
        
    } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
        NSLog(@"解析的数据----------%@",responseObject);
        
        NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:responseObject options:1 error:nil];
        
        NSArray *resultArray = dic[@"T1348648517839"];
        
        //遍历数组
        for (NSDictionary *d in resultArray) {
            DataModel *M = [DataModel new];
            [M setValuesForKeysWithDictionary:d];
            NSLog(@"model里的数据----------%@",M);
            //添加到数据源
            [self.Arr addObject:M];
            NSLog(@"Arr数据源里的数据---------%@",self.Arr);
        }
        NSLog(@"解析成功");
        [self.tbv reloadData];
        
    } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
        
        NSLog(@"解析失败");
    }];

把请求下来的数据加到cell里展示
点击cell是跳到详情页面
传值过去的是一个model不是字符串的网址

//点击cell
-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{
    NextViewController *next = [NextViewController new];
    DataModel *M = self.Arr[indexPath.row];
    NSLog(@"M.URL------------------------%@",M.url);
    next.URL = M;
    [self.navigationController pushViewController:next animated:YES];
}

第二个展示页面展示数据

//网页视图 ios12摒弃了uiwebview
    WKWebView *webview=[[WKWebView alloc]initWithFrame:CGRectMake(0, 64, self.view.frame.size.width, self.view.frame.size.height-64)];
    //将urlString转换为url
    NSURL *url=[NSURL URLWithString:self.URL.url];
    //创建请求对象
    NSURLRequest *request=[NSURLRequest requestWithURL:url];
    //网页视图加载网页
    [webview loadRequest:request];
    //添加到当前视图上
    [self.view addSubview:webview];

添加一个收藏按钮

初始化数据库 然后添加数据库
[[SqlData initData]initSql];
    
[[SqlData initData]addData:self.URL];

收藏界面搭建一个表格 视图展示出来的时候查询库

//视图展示的时候 查询数据库 有没有信息  有展示出来
-(void)viewWillAppear:(BOOL)animated{
    [[SqlData initData]initSql];
    self.array = [[SqlData initData]getDataArray];
    NSLog(@"self.array---------------------------%@",self.array);
    [self.tbv reloadData];
}

删除库

//删除
- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath{
    DataModel *M = self.array[indexPath.row];
    [[SqlData initData]deleteData:M.classid];
    self.array = [[SqlData initData]getDataArray];
    [self.tbv reloadData];
}

跳转详情页传的也是model不是字符串的网址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值