zoukankan      html  css  js  c++  java
  • FMDB的操作

    
    #import "ZYDataManager.h"
    #import "JSSportModel.h"
    FMDatabase *db = nil;
    
    @implementation ZYDataManager
    +(NSString *)dbFilePath
    {
        return [NSHomeDirectory() stringByAppendingPathComponent:@"Documents/data.sqlite"];
    }
    
    +(FMDatabase *)getDataBase
    {
        //第一次打开数据库时,db对象不存在,需要创建
        if (db == nil) {
            db = [FMDatabase databaseWithPath:[self dbFilePath]];
        }
        return db;
    }
    //
    +(void)createTable
    {
        NSLog(@"%@",NSHomeDirectory());
        if (![db open]) {
            NSAssert(NO, @"数据库打开失败");
        }
        //设置是否缓存数据
        [db setShouldCacheStatements:YES];
        
        //判断表是否存在
        if (![db tableExists:@"people"])
        {
            if (![db executeUpdate:@"create table if not exists sportTable(id INTEGER PRIMARY KEY, date TEXT, sportArray TEXT);"])
            {
                NSLog(@"数据表创建失败");
            }
        }
        
    }
    
    
    //
    +(void)addNewJSSport:(JSSportModel *)JSModel
    {
        if (![db open]) {
            NSAssert(NO, @"数据库打开失败");
        }
        
        if (![db tableExists:@"people"]) {
            [self createTable];
        }
        //?对应的字段值必须是(OC中字符串)
        if (![db executeUpdate:@"insert into sportTable (date, sportArray) values (?,?)",
              JSModel.dateStr,JSModel.arrayStr])
        {
            NSLog(@"插入数据失败");
        }
        [db close];
    }
    
    
    +(NSMutableArray *)getAllFriend
    {
        if (![db open]) {
            NSAssert(NO, @"数据库打开失败");
        }
        
        if (![db tableExists:@"sportTable"]) {
            return nil;
        }
    
        NSMutableArray *array = [[NSMutableArray alloc] initWithCapacity:0];
        FMResultSet *rs = [db executeQuery:@"select * from sportTable;"];
        //遍历所有满足条件的好友记录
        while([rs next])
        {
            JSSportModel *jssportModel = [[JSSportModel alloc] init];
    //        jssportModel.rowId = [rs intForColumn:@"id"];
            jssportModel.dateStr = [rs stringForColumn:@"date"];
            jssportModel.arrayStr = [rs stringForColumn:@"sportArray"];
            //保存好友记录
            [array addObject:jssportModel];
            
        }
       
    
        [rs close];
        [db close];
        return array ;
    }
    //
    //+(void)deleteOneFriend:(Friend *)aFriend
    //{
    //    if (![db open]) {
    //        NSAssert(NO, @"数据库打开失败");
    //    }
    //    
    //    if (![db tableExists:@"people"]) {
    //        NSLog(@"数据表不存在,不要删除");
    //    }
    //
    //    if([db executeUpdate:@"delete from people where id = ?", [NSNumber numberWithInt:aFriend.rowId]])
    //    {
    //        NSLog(@"id = %d的记录删除成功!", aFriend.rowId);
    //    }
    //    [db close];
    //}
    
    @end
    #import <Foundation/Foundation.h>
    //#import "FMDatabase.h"
    //#import "FMDatabaseAdditions.h"
    //#import "Friend.h"
    @class JSSportModel;
    @interface ZYDataManager : NSObject
    +(NSString *)dbFilePath;
    +(FMDatabase *)getDataBase;
    +(void)createTable;
    +(void)addNewJSSport:(JSSportModel *)JSModel;
    +(NSMutableArray *)getAllFriend;
    //+(void)deleteOneFriend:(Friend *)aFriend;
    @end
  • 相关阅读:
    Dump 文件生成与分析
    打造支持apk下载和html5缓存的 IIS(配合一个超简单的android APP使用)具体解释
    GridView编辑删除操作
    google域名邮箱申请 gmail域名邮箱申请(企业应用套件)指南
    nvl,空时的推断和取值
    如何将图片保存至自定义分组
    Java实现 蓝桥杯VIP 算法训练 集合运算
    Java实现 蓝桥杯VIP 算法训练 瓷砖铺放
    Java实现 蓝桥杯VIP 算法训练 瓷砖铺放
    Java实现 蓝桥杯VIP 算法训练 集合运算
  • 原文地址:https://www.cnblogs.com/keyan1102/p/4477653.html
Copyright © 2011-2022 走看看