#pragma mark - 数据库的操作

- (BOOL)judgeModel:(TaskResourceModel *)model isInArray:(NSArray *)shopArray

{

for (TaskResourceModel *shopModel in shopArray) {

if ([shopModel.resourceId isEqualToString:model.resourceId]) {

return YES;

}

}

return NO;

}

//初始化数据库数据

- (void)initTableDatas

{

//创建table

[self creatSqliteTable];

NSMutableArray *purchaceArray = [self selectPurchaceSqliteOfAllEntity];

for (TaskResourceModel *model in purchaceArray) {

NSMutableArray *shopArray = [self selectSqliteOfAllEntity];

if (![self judgeModel:model isInArray:shopArray]) {

[self insertEntityOfSourceStr:[model toJSONString] andSourceId:model.resourceId];

}

}

}

- (NSString *)sqlitePath

{

NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];

NSString * doc = documentPath;

NSString * path;

User *user = [[User alloc] getUserInformation];

switch ([self.productCategoryId integerValue]) {

case 69:

{

NSString *userSqlitePath = [NSString stringWithFormat:@"%@_%@",user.userAccountId,@"shopTaskResource_wc.sqlite"];

path = [doc stringByAppendingPathComponent:userSqlitePath];

break;

}

case 68:

{

NSString *userSqlitePath = [NSString stringWithFormat:@"%@_%@",user.userAccountId,@"shopTaskResource_sina.sqlite"];

path = [doc stringByAppendingPathComponent:userSqlitePath];

break;

}

case 88:

{

NSString *userSqlitePath = [NSString stringWithFormat:@"%@_%@",user.userAccountId,@"shopTaskResource_qq.sqlite"];

path = [doc stringByAppendingPathComponent:userSqlitePath];

break;

}

default:

break;

}

return path;

}

- (NSString *)purchaseSqlitePath

{

NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];

NSString * doc = documentPath;

NSString * path = [doc stringByAppendingPathComponent:@"taskResource.sqlite"];

return path;

}

//插

- (void)insertEntityOfSourceStr:(NSString *)sourceStr andSourceId:(NSString *)sourceId

{

NSFileManager * fileManager = [NSFileManager defaultManager];

[fileManager fileExistsAtPath:[self sqlitePath]];

//    if (![fileManager fileExistsAtPath:[self sqlitePath]]){

[self creatSqliteTable];

//    }

//    'sourceId' TEXT, 'sourceModelStr'

FMDatabase * db = [FMDatabase databaseWithPath:[self sqlitePath]];

if ([db open]) {

NSString *insertSql1= [NSString stringWithFormat:

@"INSERT INTO 'TaskSource' ('%@', '%@') VALUES ('%@', '%@')",

@"sourceId", @"sourceModelStr", sourceId, sourceStr];

BOOL res = [db executeUpdate:insertSql1];

if (!res) {

NSLog(@"error when insert db table");

} else {

NSLog(@"success to insert db table");

}

[db close];

}

}

//查所有的

- (NSMutableArray *)selectPurchaceSqliteOfAllEntity

{

NSMutableArray *array = [NSMutableArray array];

FMDatabase * db = [FMDatabase databaseWithPath:[self purchaseSqlitePath]];

if ([db open]) {

NSString *sql = @"SELECT * FROM TaskSource";

//        NSString * sql = @"select * from user";

FMResultSet * rs = [db executeQuery:sql];

while ([rs next]) {

NSString *json = [rs stringForColumn:@"sourceModelStr"];

TaskResourceModel *model = [[TaskResourceModel alloc] initWithString:json error:nil];

[array addObject:model];

}

[db close];

}

return array;

}

//查所有的

- (NSMutableArray *)selectSqliteOfAllEntity

{

NSMutableArray *array = [NSMutableArray array];

FMDatabase * db = [FMDatabase databaseWithPath:[self sqlitePath]];

if ([db open]) {

NSString *sql = @"SELECT * FROM TaskSource";

//        NSString * sql = @"select * from user";

FMResultSet * rs = [db executeQuery:sql];

while ([rs next]) {

NSString *json = [rs stringForColumn:@"sourceModelStr"];

TaskResourceModel *model = [[TaskResourceModel alloc] initWithString:json error:nil];

[array addObject:model];

}

[db close];

}

return array;

}

//删除

- (void)deletePurchaceSqliteOfSourceId:(NSString *)sourceId

{

FMDatabase * db = [FMDatabase databaseWithPath:[self purchaseSqlitePath]];

if ([db open]) {

NSString *sql = [NSString stringWithFormat:@"delete from TaskSource where sourceId = '%@'",sourceId];

//        NSString * sql = @"select * from user";

BOOL res = [db executeUpdate:sql];

if (!res) {

NSLog(@"error when delete db table");

} else {

NSLog(@"success to delete db table");

}

[db close];

}

}

//删除

- (void)deleteSqliteOfSourceId:(NSString *)sourceId

{

FMDatabase * db = [FMDatabase databaseWithPath:[self sqlitePath]];

if ([db open]) {

NSString *sql = [NSString stringWithFormat:@"delete from TaskSource where sourceId = '%@'",sourceId];

//        NSString * sql = @"select * from user";

BOOL res = [db executeUpdate:sql];

if (!res) {

NSLog(@"error when delete db table");

} else {

NSLog(@"success to delete db table");

}

[db close];

}

}

//查特定sourceid

- (TaskResourceModel *)selectSqliteOfSourceId:(NSString *)sourceId

{

FMDatabase * db = [FMDatabase databaseWithPath:[self sqlitePath]];

NSString *json;

if ([db open]) {

json = [db stringForQuery:@"SELECT sourceModelStr FROM TaskSource WHERE sourceId = ?",sourceId];

////        NSString * sql = @"select * from user";

//        FMResultSet * rs = [db executeQuery:sql];

//        while ([rs next]) {

//            NSString *json = [rs stringForColumn:@"sourceModelStr"];

//

//            model = [[TaskResourceModel alloc] initWithString:json error:nil];

////            return

//        }

[db close];

}

TaskResourceModel *model = [[TaskResourceModel alloc] initWithString:json error:nil];

return model;

}

- (void)creatSqliteTable

{

NSFileManager * fileManager = [NSFileManager defaultManager];

[fileManager fileExistsAtPath:[self sqlitePath]];

//    if (flag == NO) {

// create it

FMDatabase * db = [FMDatabase databaseWithPath:[self sqlitePath]];

if ([db open]) {

//            NSString *sqlCreateTable =  [NSString stringWithFormat:@"CREATE TABLE IF NOT EXISTS '%@' ('%@' INTEGER PRIMARY KEY AUTOINCREMENT, '%@' TEXT, '%@' INTEGER, '%@' TEXT)",TABLENAME,ID,NAME,AGE,ADDRESS];

//            BOOL res = [db executeUpdate:sqlCreateTable];

NSString * sql = @"CREATE TABLE IF NOT EXISTS 'TaskSource' ('sourceId' TEXT, 'sourceModelStr' TEXT)";

BOOL res = [db executeUpdate:sql];

if (!res) {

//                debugLog(@"error when creating db table");

} else {

//                debugLog(@"succ to creating db table");

}

[db close];

} else {

//            debugLog(@"error when open db");

}

//    }

}

+ (void)deleteAllSqliteData

{

NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];

NSString * doc = documentPath;

//    NSString *userSqlitePath = [NSString stringWithFormat:@"%@_%@",user.userAccountId,@"shopTaskResource_qq.sqlite"];

//    User *user = [[User alloc] getUserInformation];

//    NSString * wcPath = [doc stringByAppendingPathComponent:[NSString stringWithFormat:@"%@_%@",user.userAccountId,@"shopTaskResource_wc.sqlite"]];

//    NSString * sinaPath = [doc stringByAppendingPathComponent:[NSString stringWithFormat:@"%@_%@",user.userAccountId,@"shopTaskResource_sina.sqlite"]];

//    NSString * qqPath = [doc stringByAppendingPathComponent:[NSString stringWithFormat:@"%@_%@",user.userAccountId,@"shopTaskResource_qq.sqlite"]];

//    FMDatabase * db = [FMDatabase databaseWithPath:wcPath];

//    if ([db open]) {

//        NSString *sql = [NSString stringWithFormat:@"delete from TaskSource "];

//        //        NSString * sql = @"select * from user";

//        BOOL res = [db executeUpdate:sql];

//        if (!res) {

//            NSLog(@"error when delete db table");

//        } else {

//            NSLog(@"success to delete db table");

//        }

//        [db close];

//    }

//

//    FMDatabase * sinaDb = [FMDatabase databaseWithPath:sinaPath];

//    if ([sinaDb open]) {

//        NSString *sql = [NSString stringWithFormat:@"delete from TaskSource "];

//        //        NSString * sql = @"select * from user";

//        BOOL res = [sinaDb executeUpdate:sql];

//        if (!res) {

//            NSLog(@"error when delete db table");

//        } else {

//            NSLog(@"success to delete db table");

//        }

//        [sinaDb close];

//    }

//

//    FMDatabase * qqDb = [FMDatabase databaseWithPath:qqPath];

//    if ([qqDb open]) {

//        NSString *sql = [NSString stringWithFormat:@"delete from TaskSource "];

//        //        NSString * sql = @"select * from user";

//        BOOL res = [qqDb executeUpdate:sql];

//        if (!res) {

//            NSLog(@"error when delete db table");

//        } else {

//            NSLog(@"success to delete db table");

//        }

//        [qqDb close];

//    }

//

//    NSString *purchasePath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];

//    NSString * doc = documentPath;

NSString * purchasePath = [documentPath stringByAppendingPathComponent:@"taskResource.sqlite"];

//    FMDatabase * purchaseDb = [FMDatabase databaseWithPath:purchasePath];

//    if ([purchaseDb open]) {

//        NSString *sql = [NSString stringWithFormat:@"delete from TaskSource "];

//        //        NSString * sql = @"select * from user";

//        BOOL res = [purchaseDb executeUpdate:sql];

//        if (!res) {

//            NSLog(@"error when delete db table");

//        } else {

//            NSLog(@"success to delete db table");

//        }

//        [purchaseDb close];

//    }

NSFileManager * fileManager = [NSFileManager defaultManager];

////    if ([fileManager fileExistsAtPath:wcPath]){

//        NSError *error;

//        [fileManager removeItemAtPath:wcPath error:&error];

////        NSLog(@"-------:%@",error);

////    }

////    if ([fileManager fileExistsAtPath:sinaPath]){

//        [fileManager removeItemAtPath:sinaPath error:nil];

////    }

////    if ([fileManager fileExistsAtPath:qqPath]){

//        [fileManager removeItemAtPath:qqPath error:nil];

////    }

////    if ([fileManager fileExistsAtPath:purchasePath]){

[fileManager removeItemAtPath:purchasePath error:nil];

//    }

}

FMDB数据库中的一些操作的更多相关文章

  1. MySQL 数据库中的基础操作

    数据库中的表操作 1.创建表 表的表名命名规则: -- 数据库表命名规则重要说明: -- (1)数据库表名称可以支持大写字母A-Z,小写字母a-z,数字0-9,字符包括下划线 _ ,可以组合使用; - ...

  2. JDBC上关于数据库中多表操作一对多关系和多对多关系的实现方法

    黑马程序员 我们知道,在设计一个Javabean的时候,要把这些BEAN 的数据存放在数据库中的表结构,然而这些数据库中的表直接又有些特殊的关系,例如员工与部门直接有一对多的关系,学生与老师直接又多对 ...

  3. oracle数据库中常见的操作语句(一)

    一 创建表空间 create tablespace lfdc_data logging datafile 'D:\Database\lfdc_data.dbf' size 50m autoextend ...

  4. mongodb 数据库中 的聚合操作

  5. sql 指定数据库中的信息操作

    查是否有该表名 SELECT * FROM sys.objects WHERE name='表名'查表字段的信息select * from syscolumns where id=Object_Id( ...

  6. 图解数据库中的join操作

    1.所有的join都从cross join衍生而来 2.所有join图示 转自Say NO to Venn Diagrams When Explaining JOINs

  7. 数据库中DDL、DML、DCL和TCP概念

    1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ...

  8. 涂抹mysql笔记-数据库中的权限体系

    涂抹mysql笔记-数据库中的权限体系<>能不能连接,主机名是否匹配.登陆使用的用户名和密码是否正确.mysql验证用户需要检查3项值:用户名.密码和主机来源(user.password. ...

  9. 数据库mysql的常规操作

    1. 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的建立在计算机存储设备上的仓库. 简单来说是本身可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据进 ...

随机推荐

  1. WebDriver 页面等待

    selenium2.4.0版本提供了页面等待处理. 显示等待元素可见: protected void WaitElementVisible(By by,int timeOutInSeconds, lo ...

  2. [maven] 使用问题及思考汇总

    (1)Maven坐标 maven坐标可以唯一标识一个项目,包含四个元素 groupId , artifactId, packaging, version. groupId:一般为团体,公司,项目.如 ...

  3. Android 反编译工具简介

    Android 反编译工具: 所需工具:1 apktool : 用于获取资源文件 2 dex2Jar : 用于将classes.dex转化成jar文件 2 jd-gui: 将jar文件转化成java文 ...

  4. OC 实例变量(instance var)与属性(@property)的关系 isa指针

    实例变量(instance var)与属性(@property)的关系 Objective-C 2.0之后,声明一个@property name自动产生一个实例变量,名为_name,因此省去实例变量和 ...

  5. jQuery+zTree加载树形结构菜单

    jQuery+zTree加载树形结构菜单 由于项目中需要设计树形菜单功能,经过一番捣腾之后,终于给弄出来了,所以便记下来,也算是学习zTree的一个总结吧. zTree的介绍: 1.zTree 是利用 ...

  6. LevelDb简单介绍和原理——本质:类似nedb,插入数据文件不断增长(快照),再通过删除老数据做更新

    转自:http://www.cnblogs.com/haippy/archive/2011/12/04/2276064.html 有时间再好好看下整个文章! 说起LevelDb也许您不清楚,但是如果作 ...

  7. BZOJ1520 [POI2006]Szk-Schools

    裸的费用流啊... 建图:对于一个点p拆成两个p1和p2,S向p1连边,流量为1,费用为0:p2向T连边流量为1,费用为0 然后i1向a2到b2分别连边,不妨设i1向p2连边,流量为1,费用为|i - ...

  8. [转]C# 应用程序安装部署步骤,安装前操作,先退出程序后卸载。

    1. 点击[文件]-[新建]-[项目]-其他项目类型-安装和部署,选择安装项目,在下面的名称栏填写SetupTest(或者选择安装向导,一直点击[下一步])2. 安装项目----六个子项依次为:文件系 ...

  9. bzoj 2186: [Sdoi2008]沙拉公主的困惑

    #include<cstdio> #include<iostream> #define ll long long #define N 10000009 using namesp ...

  10. fseek ftell rewind

    下面几个函数的头文件 : <stdio.h>   fseek int fseek( FILE *stream, long offset, int origin ); 第一个参数stream ...