数据库操作(使用FMDB)
来源:互联网 发布:优化机构设置 编辑:程序博客网 时间:2024/05/22 03:20
iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便。于是,就出现了一系列将SQLite API进行封装的库,例如FMDB、PlausibleDatabase、sqlitepersistentobjects等,FMDB (https://github.com/ccgus/fmdb) 是一款简洁、易用的封装库,这一篇文章简单介绍下FMDB的使用。
在FMDB下载文件后,工程中必须导入如下文件,并使用 libsqlite3.dylib 依赖包。
FMDB同时兼容ARC和非ARC工程,会自动根据工程配置来调整相关的内存管理代码。
FMDB常用类:
FMDatabase : 一个单一的SQLite数据库,用于执行SQL语句。
FMResultSet :执行查询一个FMDatabase结果集,这个和android的Cursor类似。
FMDatabaseQueue :在多个线程来执行查询和更新时会使用这个类。
创建一个类 其方法可以被其它类共用 作为存储(单列为主)
#import <Foundation/Foundation.h>#import "FMDatabase.h"#import "WYShopCarModel.h"#import "NewsModel.h"@interface WYDataBase : NSObject{ //数据库 FMDatabase *_database;}//获取数据库管理对象单例的方法+ (WYDataBase *)sharedDataBase;//返回数据的路径+ (NSString *)getDataBasePath;//关闭数据库- (void)closeDataBase;//清空数据库- (BOOL)deleteDatabase;/*********** *搜索记录模块 **************///向搜索记录表中插入新记录- (BOOL)insertSeachText:(NSString *)seachText;//查询数据库中是否包含当前搜索记录- (BOOL)isExistSeachText:(NSString *)seachText;//获取所有搜索记录- (NSMutableArray *)getAllSeachText;//删除所有搜索记录- (BOOL)deleAllSeachText;/*********** *购物车模块 **************///向购物车中添加信息- (BOOL)insertPdcToCarWithModel:(WYShopCarModel *)model;//向购物车(兴趣)中添加信息- (BOOL)insertPdcToIntrestCarWithModel:(WYShopCarModel *)model;//获取购物车(兴趣)列表- (NSArray *)getAllpdcInIntrestCar;//购物车是否存在商品- (BOOL)isExistInCarWithModel:(WYShopCarModel*)model;//获取购物车列表- (NSArray *)getAllpdcInCar;//修改购物车中产品的数量- (BOOL)updataCountInCar:(int)newCount pdc:(int)pdcSID;//修改购物车中产品的选中状态- (BOOL)updateSelectedState:(int)select pdc:(int)pdcId;//删除购物车中得产品记录- (BOOL)deletePdcInCarById:(int)pdcSId;/*********** *系统消息模块 **************///插入一条消息- (BOOL)insertNewToTBNew:(NewsModel *)model;//判断消息是否存在记录中- (BOOL)isExitInTabNew:(NSString *)newId;//改变消息是否阅读过的状态- (BOOL)changeScanfFlagWithNewId:(NSString *)newId;//获取一个model比对- (NewsModel *)getNewsModelById:(NSString *)newId;//获取所有的消息记录- (NSArray *)getAllNews;
实现
#import "WYDataBase.h"#import "WYShopCarModel.h"#import "ShoppingCarVC.h"//定义单例对象#pragma mark -- 单例对象获取//static WYDataBase *wydatase;@implementation WYDataBase- (id)init{ if (self = [super init]) { //初始化数据库对象 并打开 _database = [FMDatabase databaseWithPath:[WYDataBase getDataBasePath]]; //如果数据库打开失败返回空值 if (![_database open]) { return nil; } } //如果数据库打开成功 创建表 //创建搜索历史记录表 NSString *sql = @"create table if not exists tb_history(tb_id integer primary key autoincrement,seachText text)"; //创建购物车表 NSString *sql2 = @"create table if not exists tb_car(carId integer primary key autoincrement,pdcId text,pdcSID text,img text,selected text,name text,price float,yprice float,allcnt text,qishu text,allneed text,leftneed text)"; //创建兴趣推荐表 NSString *sql3 = @"create table if not exists tb_intrest_car(carId integer primary key autoincrement,pdcID text,pdcSID text,img text,selected integer,name text,price float,yprice float,allcnt integer)"; //创建系统消息表 NSString *sql4 = @"create table if not exists tb_News(tb_id integer primary key autoincrement, integer,newTitle text,newTime text,isScanfed integer)"; BOOL is = [_database executeUpdate:sql]; BOOL is2 = [_database executeUpdate:sql2]; BOOL is3 = [_database executeUpdate:sql3]; BOOL is4 = [_database executeUpdate:sql4]; if (is2 && is && is3 && is4) { NSLog(@"创建表成功!"); } return self;}//获取数据库管理对象单例的方法+ (WYDataBase *)sharedDataBase{ static WYDataBase *wydatase = nil; static dispatch_once_t once; dispatch_once(&once, ^{ wydatase = [[WYDataBase alloc]init]; }); return wydatase;}//返回数据库的路径+ (NSString *)getDataBasePath{ NSString *path = [NSHomeDirectory() stringByAppendingPathComponent:@"Documents"];// NSLog(@"home:%@",path); return [path stringByAppendingPathComponent:@"wy.db"];}//查询数据库中是否包含当前搜索记录- (BOOL)isExistSeachText:(NSString *)seachText{ NSString *sql = @"select * from tb_history"; FMResultSet *results = [_database executeQuery:sql]; while (results.next) { if ([seachText isEqualToString:[results stringForColumn:@"seachText"]]) { return YES; } } return NO;}//向搜索记录表中插入新记录- (BOOL)insertSeachText:(NSString *)seachText{ // 若果传入参数为空 或者数据库中存在该条记录 则插入数据失败 if (!seachText||[seachText isEqualToString:@""]||[self isExistSeachText:seachText]) { NSLog(@"数据已存在"); return NO; } NSString *sql = @"insert into tb_history(seachText) values (?)"; BOOL isInsertOK = [_database executeUpdate:sql,seachText]; if (isInsertOK) { NSLog(@"%@-->插入成功",seachText); return YES; } NSLog(@"%@-->插入失败",seachText); return NO;}//获取所有搜索记录- (NSMutableArray *)getAllSeachText{ NSString *sql = @"select * from tb_history order by tb_id desc"; //保存所有数据的数组 NSMutableArray *seachTexts = [NSMutableArray array]; FMResultSet *results = [_database executeQuery:sql]; while (results.next) { NSString *result = [results stringForColumn:@"seachText"]; [seachTexts addObject:result]; } return seachTexts;}//删除所有搜索记录- (BOOL)deleAllSeachText{ NSString *sql = @"delete from tb_history"; BOOL isDeleteOK = [_database executeUpdate:sql]; if (isDeleteOK) {// NSLog(@"删除成功"); return YES; } return NO;}#pragma mark -- 购物车模块/*********** *购物车模块 **************///向购物车中添加信息- (BOOL)insertPdcToCarWithModel:(WYShopCarModel *)model{ // NSString *sql2 = @"create table if not exists tb_car(carId integer primary key autoincrement,pdcId text,pdcSID text,img text,selected integer,name text,price float,yprice float,allcnt integer,qishu integer)";// if([model.left_need intValue] == 0){return NO;}// if ([model.left_need intValue] < 5) {// NSString *sqll = @"insert into tb_car(pdcId,pdcSID,img,name,allcnt,qishu,allneed,leftneed) values (?,?,?,?,?,?,?,?)";// BOOL isOK = [_database executeUpdate:sqll,model.car_id,model.car_new_id,model.imgPath,model.name,model.left_need ,model.qishu,model.all_need,model.left_need];// if (isOK) {// ShoppingCarVC *shopVC = [ShoppingCarVC shareShoppingCarVC];// shopVC.firstFlag = YES;//// return YES;// }// } if ([self isExistInCar:[model.car_new_id intValue]]) {// [self deletePdcInCarById:[model.car_id intValue]]; return NO; } /***************如果该产品在购物车中不存在,加入购物车*******************/ NSString *sql = @"insert into tb_car(pdcId,pdcSID,img,name,allcnt,qishu,allneed,leftneed) values (?,?,?,?,?,?,?,?)"; BOOL isInsertOK = [_database executeUpdate:sql,model.car_id,model.car_new_id, model.imgPath,model.name,@"5",model.qishu ,model.all_need,model.left_need]; if (isInsertOK) { NSLog(@"%@-->插入成功",model.car_id); return YES; } return NO;}//查询购物车中是否包含此产品记录- (BOOL)isExistInCar:(int)pdcSID{ NSString *sql = @"select * from tb_car"; FMResultSet *results = [_database executeQuery:sql]; while (results.next) { NSString *pdcSID2 = [results stringForColumn:@"pdcSID"];// NSString *pdcID = [results stringForColumn:@"pdcId"]; if (pdcSID == pdcSID2.intValue) { return YES; } } return NO;}- (BOOL)isExistInCarWithModel:(WYShopCarModel *)model{ return [self isExistInCar:model.car_new_id.intValue];}//获取购物车列表- (NSArray *)getAllpdcInCar{// NSString *sql2 = @"create table if not exists tb_car(carId integer primary key autoincrement,pdcId text,pdcSID text,img text,selected text,name text,price float,yprice float,allcnt text,qishu text)"; NSString *sql = @"select * from tb_car order by carId desc"; FMResultSet *results = [_database executeQuery:sql]; NSMutableArray *arr = [NSMutableArray array]; while (results.next) { WYShopCarModel *model = [[WYShopCarModel alloc]init]; model.car_id = [NSString stringWithFormat:@"%d",[results intForColumn:@"pdcId"]]; model.car_new_id = [NSString stringWithFormat:@"%d",[results intForColumn:@"pdcSID"]]; model.name = [results stringForColumn:@"name"]; model.count = [results intForColumn:@"allcnt"]; model.imgPath = [results stringForColumn:@"img"]; model.qishu = [results stringForColumn:@"qishu"]; model.all_need = [results stringForColumn:@"allneed"]; model.left_need = [results stringForColumn:@"leftneed"]; [arr addObject:model]; } return arr;}//修改购物车中产品的数量- (BOOL)updataCountInCar:(int)newCount pdc:(int)pdcSID{ if(![self isExistInCar:pdcSID])/********如果购物车中没有该产品*********/ { return NO; } NSString *sqll = @"update tb_car set allcnt = ? where pdcSID = ?"; BOOL isOK = [_database executeUpdate:sqll,[NSString stringWithFormat:@"%d",newCount],[NSString stringWithFormat:@"%d",pdcSID]]; if (isOK) { return YES; } return NO;}//修改购物车中产品的选中状态- (BOOL)updateSelectedState:(int)select pdc:(int)pdcId{ if(![self isExistInCar:pdcId])/********如果购物车中没有该产品*********/ { return NO; } NSString *sqll = @"update tb_car set selected = ? where pdcId = ?"; BOOL isOK = [_database executeUpdate:sqll,[NSString stringWithFormat:@"%d",select],[NSString stringWithFormat:@"%d",pdcId]]; if (isOK) { return YES; } return NO;}//删除购物车中得产品记录- (BOOL)deletePdcInCarById:(int)pdcSID{ if(![self isExistInCar:pdcSID])/********如果购物车中没有该产品*********/ { return NO; } NSString *sqll = @"delete from tb_car where pdcSID = ?"; BOOL isOK = [_database executeUpdate:sqll,[NSString stringWithFormat:@"%d",pdcSID]]; if (isOK) { return YES; } return NO;} #pragma mark - 兴趣记录/*************** *兴趣记录部分 *****************///向购物车(兴趣)中添加信息- (BOOL)insertPdcToIntrestCarWithModel:(WYShopCarModel *)model{ if ([self isExistInIntrestCar:model.car_new_id.intValue]) {/***************如果该产品已存在于购物车,删掉*******/ [self deleIntrestPadWithId:model.car_new_id]; } /***************加入购物车*******************/ NSString *sql = @"insert into tb_intrest_car(pdcID,pdcSID,img,name,allcnt) values (?,?,?,?,?)"; BOOL isInsertOK = [_database executeUpdate:sql,model.car_id,model.car_new_id, model.imgPath,model.name,[NSNumber numberWithInt:1]]; if (isInsertOK) { return YES; } return NO;}//查询购物车(兴趣)中是否包含此产品记录- (BOOL)isExistInIntrestCar:(int)pdcSID{ NSString *sql = @"select * from tb_intrest_car where pdcSID = ?"; FMResultSet *results = [_database executeQuery:sql,[NSNumber numberWithInt:pdcSID]]; while (results.next) { NSString * pdcSID2 = [results stringForColumn:@"pdcSID"]; if (pdcSID == pdcSID2.intValue) { return YES; } } return NO;}//广东省深圳市南山区南头街道南海大道西海明珠大厦F座11楼B11//删除兴趣中某一条数据- (BOOL)deleIntrestPadWithId:(NSString*)pdcSID{ NSString *sqll = @"delete from tb_intrest_car where pdcSID = ?"; BOOL isOK = [_database executeUpdate:sqll,pdcSID]; if (isOK) {// NSLog(@"删除成功"); return YES; } NSLog(@"删除失败"); return NO;}//获取购物车(兴趣)列表- (NSArray *)getAllpdcInIntrestCar{ NSString *sql = @"select * from tb_intrest_car order by carId desc"; FMResultSet *results = [_database executeQuery:sql]; NSMutableArray *arr = [NSMutableArray array]; while (results.next) { WYShopCarModel *model = [[WYShopCarModel alloc]init]; model.car_id = [NSString stringWithFormat:@"%d",[results intForColumn:@"pdcId"]]; model.name = [results stringForColumn:@"name"]; model.count = [results intForColumn:@"allcnt"]; model.imgPath = [results stringForColumn:@"img"]; [arr addObject:model]; } return arr;}/*********** *系统消息模块 **************///插入一条消息- (BOOL)insertNewToTBNew:(NewsModel *)model{ if ([WYPublic getUsefullStr:model.news_id].length == 0 || [self isExitInTabNew:model.news_id]) {/***************如果该产品已存在于购物车*******/ return NO; } /***************加入购物车*******************/ NSString *sql = @"insert into tb_News(newId,newTitle,newTime,isScanfed) values (?,?,?,?)"; BOOL isInsertOK = [_database executeUpdate:sql,model.news_id,model.news_title,model.news_time,[NSNumber numberWithInt:model.isScanfedFlag]]; if (isInsertOK) { return YES; } return NO;}//判断消息是否存在记录中- (BOOL)isExitInTabNew:(NSString *)newId{ NSString *sql = @"select * from tb_News where newId = ?"; FMResultSet *results = [_database executeQuery:sql,[NSNumber numberWithInt:[newId intValue]]]; while (results.next) { if ([newId isEqualToString:[results stringForColumn:@"newId"]]) { return YES; } } return NO;}//改变消息是否阅读过的状态- (BOOL)changeScanfFlagWithNewId:(NSString *)newId{ if(![self isExitInTabNew:newId])/********如果记录中没有该消息*********/ { return NO; } NSString *sqll = @"update tb_News set isScanfed = ? where newId = ?"; BOOL isOK = [_database executeUpdate:sqll,[NSNumber numberWithInt:1],newId]; if (isOK) { return YES; } return NO;}//获取一个model比对- (NewsModel *)getNewsModelById:(NSString *)newId{ NSString *sql = @"select * from tb_News where newId = ?"; FMResultSet *results = [_database executeQuery:sql,newId]; while (results.next) { NewsModel *model = [[NewsModel alloc]init]; model.news_id = [results stringForColumn:@"newId"]; model.news_title = [results stringForColumn:@"newTitle"]; model.isScanfedFlag = [results intForColumn:@"isScanfed"]; model.news_time = [results stringForColumn:@"newTime"]; return model; } return nil;}//获取所有的消息记录- (NSArray *)getAllNews{ NSString *sql = @"select * from tb_News order by tb_id desc"; FMResultSet *results = [_database executeQuery:sql]; NSMutableArray *arr = [NSMutableArray array]; while (results.next) { NewsModel *model = [[NewsModel alloc]init]; model.news_id = [results stringForColumn:@"newId"]; model.news_title = [results stringForColumn:@"newTitle"]; model.isScanfedFlag = [results intForColumn:@"isScanfed"]; model.news_time = [results stringForColumn:@"newTime"]; [arr addObject:model]; } return arr;}//清空数据库- (BOOL)deleteDatabase{ NSString *sql1 = @"delete from tb_car"; NSString *sql2 = @"delete from tb_history"; NSString *sql3 = @"delete from tb_intrest_car"; BOOL isOK1 = [_database executeUpdate:sql1]; BOOL isOK2 = [_database executeUpdate:sql2]; BOOL isOK3 = [_database executeUpdate:sql3]; if (isOK1 && isOK2 && isOK3) { return YES; } return NO;}//关闭数据库- (void)closeDataBase{ if (_database) { [_database close]; }}
0 0
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 使用FMDB操作数据库
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库操作(使用FMDB)
- 数据库-数据库操作(使用FMDB)
- iOS数据库操作(使用FMDB)
- 使用FMDB进行数据库操作
- KIS商贸版专业软件系列5.0易用性补丁包,最新更新
- java中文乱码问题----java不同场景编码转换过程
- 怎样验证软件是否可信?是否被篡改?
- ios开发记录 :cocoapods 使用
- 网站开发引入优酷视频去除广告解决方案
- 数据库操作(使用FMDB)
- netstat -ano 查看机器端口占用情况
- 一些页面布局常见CSS问题
- SGI STL源码之内存配置
- hdu1166题解
- 40. Combination Sum II
- 解决onActivityResult方法不执行的办法
- spring struts2,ibatis,hibernate知识点
- SpringMVC 环境下的中文乱码解决