[iOS]列表已读/文章收藏

2024-08-20 23:32
文章标签 文章 列表 ios 收藏 已读

本文主要是介绍[iOS]列表已读/文章收藏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[iOS]列表已读/文章收藏


Demo:http://download.csdn.net/detail/u012881779/9476772

收藏


#import "FavManager.h"
#import "BaseDB.h"
#import "SBJson.h"@implementation FavManager- (void)addToFavarite:(NSDictionary *)dic FavType:(FAVTYPE)favType{NSDictionary *_dic=[NSDictionary dictionaryWithDictionary:dic];BaseDB *baseDB=[[BaseDB alloc] init];[baseDB openDB];//favtimestamp[baseDB createTable:@"Favarites" columns:@"aid INTEGER PRIMARY KEY,json text,favType integer,dateTime text"];NSMutableArray *arr=[NSMutableArray arrayWithObjects:[_dic objectForKey:@"id"]==NULL?[_dic objectForKey:@"gid"]:[_dic objectForKey:@"id"],[_dic JSONRepresentation],[NSNumber numberWithInt:favType],[NSString stringWithFormat:@"%.f",[[NSDate date] timeIntervalSince1970]], nil];[baseDB insertTableValues:@"Favarites" values:arr];[baseDB closeDB];[baseDB release];
}- (BOOL)hasFavarited:(NSString *)aid{BaseDB *baseDB=[[BaseDB alloc] init];[baseDB openDB];NSInteger i = [[baseDB selectForColumn:@"aid" value:aid tableName:@"Favarites"] count];[baseDB closeDB];[baseDB release];return i>0?YES:NO;
}- (NSArray *)fetchFavariteList:(FAVTYPE)favType{BaseDB *baseDB=[[BaseDB alloc] init];[baseDB openDB];NSMutableArray *listArray=[NSMutableArray array];NSArray *temp=[NSArray array];temp=[baseDB selectSequence:[NSString stringWithFormat:@"SELECT * FROM Favarites WHERE favType=%d order by dateTime desc",favType]];for (int i = 0 ; i<[temp count]; i++) {NSDictionary *dic = [[[temp objectAtIndex:i] objectForKey:@"json"] JSONValue];NSMutableDictionary *mDict = [dic mutableCopy];[mDict setObject:[NSString stringWithFormat:@"%d",favType] forKey:@"favtype"];[mDict setObject:[[temp objectAtIndex:i] objectForKey:@"dateTime"] forKey:@"dateTime"];[listArray addObject:mDict];[mDict release];}[baseDB closeDB];[baseDB release];return listArray;
}- (void)deleteFromFavarite:(NSString *)aid{BaseDB *baseDB=[[BaseDB alloc] init];[baseDB openDB];[baseDB deleteForColumn:@"aid" value:aid tableName:@"Favarites"];[baseDB closeDB];[baseDB release]; 
}- (void)clearFavarites{BaseDB *baseDB=[[BaseDB alloc] init];[baseDB openDB];[baseDB deleteAll:@"Favarites"];[baseDB closeDB];[baseDB release];
}//收藏已读、未读
+ (void)setRead:(NSString *)aid{BaseDB *baseDB=[[BaseDB alloc] init];[baseDB openDB];if (![baseDB tableExists:@"ListStatus"]) {[baseDB createTable:@"ListStatus" columns:@"aid INTEGER PRIMARY KEY"];}[baseDB executeSQL:[NSString stringWithFormat:@"INSERT INTO ListStatus VALUES(%@)",aid]];[baseDB closeDB];[baseDB release];
}+ (BOOL)hasRead:(NSString *)aid{BaseDB *baseDB=[[BaseDB alloc] init];[baseDB openDB];NSInteger i=[[baseDB selectForColumn:@"aid" value:aid tableName:@"ListStatus"] count];[baseDB closeDB];[baseDB release];return i > 0?YES:NO;
}@end

数据库


#import "BaseDB.h"
#import <Foundation/Foundation.h>
#import "FMDatabase.h"
#import "FMDatabaseAdditions.h"
#import "FMResultSet.h"
@interface BaseDB : NSObject{
FMDatabase *fmdb;
}
@implementation BaseDB
@synthesize fmdb;- (void)dealloc{self.fmdb   = nil;[super dealloc];
}-(void)openDB{NSString *documentsDirectory =NSHomeDirectory();NSString *path = [documentsDirectory stringByAppendingPathComponent:@"/Library/Caches/Caches.db"];NSFileManager *fileManager=[[NSFileManager alloc] init];if ([fileManager fileExistsAtPath:path]) {fmdb=[[FMDatabase alloc] initWithPath:path];if ([fmdb open]) {}}else{fmdb=[[FMDatabase alloc] initWithPath:path];if ([fmdb open]) {NSLog(@"创建了数据库并打开数据库成功!");}}[fileManager release];
}-(void)openDBMS{NSString *documentsDirectory =NSHomeDirectory();NSString *path = [documentsDirectory stringByAppendingPathComponent:@"/Library/Dbms"];NSFileManager *fileManager=[[NSFileManager alloc] init];if(![fileManager fileExistsAtPath:path]){[fileManager createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];}NSString *filePath = [path stringByAppendingFormat:@"/Dbms.db"];if ([fileManager fileExistsAtPath:filePath]) {fmdb=[[FMDatabase alloc] initWithPath:filePath];if ([fmdb open]) {}}else{fmdb=[[FMDatabase alloc] initWithPath:filePath];if ([fmdb open]) {NSLog(@"创建了数据库并打开数据库成功!");}}[fileManager release];
}-(BOOL) tableExists:(NSString *)tableName{return [fmdb tableExists:tableName];
}-(void)deleteAll:(NSString *)tableName{NSString *sql=[NSString stringWithFormat:@"DELETE FROM %@",tableName];[fmdb executeUpdate:sql];
}-(void) deleteForColumn:(NSString *)columnName value:(NSString *)v tableName:(NSString *)name{NSString *sql=[NSString stringWithFormat:@"DELETE FROM %@ WHERE %@='%@'",name,columnName,v];NSLog(@"%@",sql);[fmdb executeUpdate:sql];
}- (void)deleteSQLString:(NSString *)condition tableName:(NSString *)name{NSString *sql=[NSString stringWithFormat:@"DELETE FROM %@ WHERE %@",name,condition];[fmdb executeUpdate:sql];
}-(void)createTable:(NSString *)tableName columns:(NSString *)columnsName{NSString *sql=[NSString stringWithFormat:@"CREATE TABLE %@ (%@)",tableName,columnsName];[fmdb executeUpdate:sql];
}-(void)insertTableValues:(NSString *)tableName values:(NSMutableArray *)Values{NSMutableString *sql=[[NSMutableString alloc] init];NSMutableArray *tempArray=[[NSMutableArray alloc] initWithArray:Values];[sql appendFormat:@"INSERT INTO %@ VALUES(",tableName];for (int i=0; i<[Values count]; i++) {if (i==[Values count]-1) {[sql appendFormat:@"?)"];}else{[sql appendFormat:@"?,"];}}[fmdb executeUpdate:sql withArgumentsInArray:tempArray];[sql release];[tempArray release];
}- (void)executeSQL:(NSString *)sql{[fmdb executeUpdate:sql];
}-(NSMutableArray *)selectAll:(NSString *)tableName{NSString *sql=[NSString stringWithFormat:@"SELECT * FROM %@",tableName];FMResultSet *rs=[fmdb executeQuery:sql];NSMutableArray *list=[[NSMutableArray alloc] init];while ([rs next]) {NSMutableDictionary *temp=[[NSMutableDictionary alloc] init];for (int i=0; i<[rs columnCount]; i++) {[temp addEntriesFromDictionary:[NSDictionary dictionaryWithObject:[rs stringForColumn:[rs columnNameForIndex:i]] forKey:[rs columnNameForIndex:i]]];}[list addObject:temp];[temp release];}return [list autorelease];
}-(NSMutableArray *)selectForColumn:(NSString *)columnName value:(NSString *)v tableName:(NSString *)name{NSString *sql=[NSString stringWithFormat:@"SELECT * FROM %@ WHERE %@='%@'",name,columnName,v];FMResultSet *rs=[fmdb executeQuery:sql];NSMutableArray *list=[[NSMutableArray alloc] init];while ([rs next]) {NSMutableDictionary *temp=[[NSMutableDictionary alloc] init];for (int i=0; i<[rs columnCount]; i++) {[temp addEntriesFromDictionary:[NSDictionary dictionaryWithObject:[rs stringForColumn:[rs columnNameForIndex:i]] forKey:[rs columnNameForIndex:i]]];}[list addObject:temp];[temp release];}return [list autorelease];
}-(NSMutableArray *) selectForNotColumn:(NSString *)columnName value:(NSString *)v tableName:(NSString *)name{NSString *sql=[NSString stringWithFormat:@"SELECT * FROM %@ WHERE %@!='%@'",name,columnName,v];FMResultSet *rs=[fmdb executeQuery:sql];NSMutableArray *list=[[NSMutableArray alloc] init];while ([rs next]) {NSMutableDictionary *temp=[[NSMutableDictionary alloc] init];for (int i=0; i<[rs columnCount]; i++) {[temp addEntriesFromDictionary:[NSDictionary dictionaryWithObject:[rs stringForColumn:[rs columnNameForIndex:i]] forKey:[rs columnNameForIndex:i]]];}[list addObject:temp];[temp release];}return [list autorelease] ;
}-(void)updateForColumn:(NSString *)columnName value:(NSString *)v tableName:(NSString *)name whereColumn:(NSString *)where whereValue:(NSString *)whereV{NSString *sql=[NSString stringWithFormat:@"UPDATE %@ SET %@='%@' WHERE %@='%@'",name,columnName,v,where,whereV];[fmdb executeUpdate:sql];
}-(NSMutableArray *)selectSequence:(NSString *)sql{NSLog(@"SQL:%@",sql);FMResultSet *rs=[fmdb executeQuery:sql];NSMutableArray *list=[[NSMutableArray alloc] init];while ([rs next]) {NSMutableDictionary *temp=[[NSMutableDictionary alloc] init];for (int i=0; i<[rs columnCount]; i++) {[temp addEntriesFromDictionary:[NSDictionary dictionaryWithObject:[rs stringForColumn:[rs columnNameForIndex:i]] forKey:[rs columnNameForIndex:i]]];}[list addObject:temp];[temp release];}return [list autorelease];    
}@end


示意图


这篇关于[iOS]列表已读/文章收藏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1091483

相关文章

Python中合并列表(list)的六种方法小结

《Python中合并列表(list)的六种方法小结》本文主要介绍了Python中合并列表(list)的六种方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、直接用 + 合并列表二、用 extend() js方法三、用 zip() 函数交叉合并四、用

Spring Boot中的YML配置列表及应用小结

《SpringBoot中的YML配置列表及应用小结》在SpringBoot中使用YAML进行列表的配置不仅简洁明了,还能提高代码的可读性和可维护性,:本文主要介绍SpringBoot中的YML配... 目录YAML列表的基础语法在Spring Boot中的应用从YAML读取列表列表中的复杂对象其他注意事项总

C++类和对象之初始化列表的使用方式

《C++类和对象之初始化列表的使用方式》:本文主要介绍C++类和对象之初始化列表的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C++初始化列表详解:性能优化与正确实践什么是初始化列表?初始化列表的三大核心作用1. 性能优化:避免不必要的赋值操作2. 强

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

Python中DataFrame转列表的最全指南

《Python中DataFrame转列表的最全指南》在Python数据分析中,Pandas的DataFrame是最常用的数据结构之一,本文将为你详解5种主流DataFrame转换为列表的方法,大家可以... 目录引言一、基础转换方法解析1. tolist()直接转换法2. values.tolist()矩阵

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

python展开嵌套列表的多种方法

《python展开嵌套列表的多种方法》本文主要介绍了python展开嵌套列表的多种方法,包括for循环、列表推导式和sum函数三种方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、嵌套列表格式二、嵌套列表展开方法(一)for循环(1)for循环+append()(2)for循环+pyPhWiFd

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D