[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

相关文章

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

java计算机毕设课设—停车管理信息系统(附源码、文章、相关截图、部署视频)

这是什么系统? 资源获取方式在最下方 java计算机毕设课设—停车管理信息系统(附源码、文章、相关截图、部署视频) 停车管理信息系统是为了提升停车场的运营效率和管理水平而设计的综合性平台。系统涵盖用户信息管理、车位管理、收费管理、违规车辆处理等多个功能模块,旨在实现对停车场资源的高效配置和实时监控。此外,系统还提供了资讯管理和统计查询功能,帮助管理者及时发布信息并进行数据分析,为停车场的科学

文章解读与仿真程序复现思路——电力自动化设备EI\CSCD\北大核心《考虑燃料电池和电解槽虚拟惯量支撑的电力系统优化调度方法》

本专栏栏目提供文章与程序复现思路,具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源程序擅长文章解读,论文与完整源程序,等方面的知识,电网论文源程序关注python

Exchange 服务器地址列表的配置方法与注意事项

Exchange Server 是微软推出的一款企业级邮件服务器软件,广泛应用于企业内部邮件系统的搭建与管理。配置 Exchange 服务器地址列表是其中一个关键环节。本文将详细介绍 Exchange 服务器地址列表的配置方法与注意事项,帮助系统管理员顺利完成这一任务。 内容目录 1. 引言 2. 准备工作 3. 配置地址列表 3.1 创建地址列表 3.2 使用 Exchange

收藏:解决 pip install 出现 error: subprocess-exited-with-error 错误的方法

在使用 pip 安装 Python 包时,有时候会遇到 error: subprocess-exited-with-error 错误。这种错误通常是由于 setuptools 版本问题引起的。本文将介绍如何解决这一问题 当你使用 pip install 安装某个 Python 包时,如果 setuptools 版本过高或过低,可能会导致安装过程出错,并出现类似以下错误信息:error: subpr

iOS剪贴板同步到Windows剪贴板(无需安装软件的方案)

摘要 剪贴板同步能够提高很多的效率,免去复制、发送、复制、粘贴的步骤,只需要在手机上复制,就可以直接在电脑上 ctrl+v 粘贴,这方面在 Apple 设备中是做的非常好的,Apple 设备之间的剪贴板同步功能(Universal Clipboard)确实非常方便,它可以在 iPhone、iPad 和 Mac 之间无缝传输剪贴板内容,从而大大提高工作效率。 但是,iPhone 如何和 Wind

Python--列表简介

列表是什么 列表让你能够在⼀个地方存储成组的信息,其中既可以只包含几个元素,也可以包含数百万个元素。列表是新手可直接使用的最强大的Python 功能之⼀。 列表(list)是一种可变的序列类型,用于存储一系列有序的元素。这些元素可以是任何类型,包括整数、浮点数、字符串、其他列表(即嵌套列表)等。列表是动态的,可以在运行时增加或删除元素。 用方括号([ ])表示列表,用逗号分隔其中的元素。