ios 对FMDB 简单封装
2016-05-27 11:30
375 查看
声明部分
// 插入模型数据
+ (BOOL)insertModelWithKey:(NSString )key andValue:(NSString )value;
/* 查询数据,如果 传空 默认会查询表中所有数据 /
+ (NSMutableDictionary )queryData:(NSString )querySql;
/* 删除数据,如果 传空 默认会删除表中所有数据 /
+(BOOL)deleteDataTableWithKey:(NSString *)keyStr;
/* 修改数据 /
+ (BOOL)modifyData:(NSString )valueStr key:(NSString )keyStr;
@end
static FMDatabase *_fmdb;
(void)initialize {
// 执行打开数据库和创建表操作
NSString *filePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:LVSQLITE_NAME];
_fmdb = [FMDatabase databaseWithPath:filePath];
[_fmdb open];
}
+(BOOL)insertModelWithKey:(NSString )key andValue:(NSString )value
{
NSString *insertSql = [NSString stringWithFormat:@”INSERT INTO t_modals(key, value) VALUES (‘%@’, ‘%@’);”, key,value];
return [_fmdb executeUpdate:insertSql];
}
/*
+ (BOOL)insertModel:(LVModel *)model {
NSString *insertSql = [NSString stringWithFormat:@”INSERT INTO t_modals(key, value) VALUES (‘%@’, ‘%@’);”, model.name, model.age, model.ID_No];
return [_fmdb executeUpdate:insertSql];
}
*/
+(NSMutableDictionary )queryData:(NSString )querySql
{
if (querySql == nil) {
querySql = @”SELECT * FROM t_modals;”;
}
else
{
querySql =[NSString stringWithFormat:@”SELECT * FROM t_modals WHERE key =’%@’”,querySql];
}
NSMutableDictionary * resultDic = [[NSMutableDictionary alloc]initWithCapacity:5];
FMResultSet *rs = [_fmdb executeQuery:querySql];
while ([rs next])
{
[resultDic setObject:[rs stringForColumn:@”value”] forKey:[rs stringForColumn:@”key”]];
DLog(@”查询到数据”);
}
/*
+ (NSArray )queryData:(NSString )querySql {
}
*/
+(BOOL)deleteDataTableWithKey:(NSString *)keyStr
{
//NSString *sqlStr=;
return [_fmdb executeUpdate:@”DELETE FROM t_modals WHERE key=?”,keyStr];
}
/*
+ (BOOL)deleteData:(NSString *)deleteSql {
}
*/
+(BOOL)modifyData:(NSString )valueStr key:(NSString )keyStr
{
return [_fmdb executeUpdate:@”UPDATE t_modals SET value=? WHERE key=?”,valueStr,keyStr];
}
/*
+ (BOOL)modifyData:(NSString *)modifySql {
}
*/
@end
import “FMDB.h”
@interface LVFmdbTool : NSObject// 插入模型数据
+ (BOOL)insertModelWithKey:(NSString )key andValue:(NSString )value;
/* 查询数据,如果 传空 默认会查询表中所有数据 /
+ (NSMutableDictionary )queryData:(NSString )querySql;
/* 删除数据,如果 传空 默认会删除表中所有数据 /
+(BOOL)deleteDataTableWithKey:(NSString *)keyStr;
/* 修改数据 /
+ (BOOL)modifyData:(NSString )valueStr key:(NSString )keyStr;
@end
实现部分
import “LVFmdbTool.h”
define LVSQLITE_NAME @”modals.sqlite”
@implementation LVFmdbToolstatic FMDatabase *_fmdb;
(void)initialize {
// 执行打开数据库和创建表操作
NSString *filePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:LVSQLITE_NAME];
_fmdb = [FMDatabase databaseWithPath:filePath];
[_fmdb open];
warning 必须先打开数据库才能创建表。。。否则提示数据库没有打开
[_fmdb executeUpdate:@"CREATE TABLE IF NOT EXISTS t_modals(id INTEGER PRIMARY KEY, key TEXT NOT NULL, value TEXT NOT NULL);"];
}
+(BOOL)insertModelWithKey:(NSString )key andValue:(NSString )value
{
NSString *insertSql = [NSString stringWithFormat:@”INSERT INTO t_modals(key, value) VALUES (‘%@’, ‘%@’);”, key,value];
return [_fmdb executeUpdate:insertSql];
}
/*
+ (BOOL)insertModel:(LVModel *)model {
NSString *insertSql = [NSString stringWithFormat:@”INSERT INTO t_modals(key, value) VALUES (‘%@’, ‘%@’);”, model.name, model.age, model.ID_No];
return [_fmdb executeUpdate:insertSql];
}
*/
+(NSMutableDictionary )queryData:(NSString )querySql
{
if (querySql == nil) {
querySql = @”SELECT * FROM t_modals;”;
}
else
{
querySql =[NSString stringWithFormat:@”SELECT * FROM t_modals WHERE key =’%@’”,querySql];
}
NSMutableDictionary * resultDic = [[NSMutableDictionary alloc]initWithCapacity:5];
FMResultSet *rs = [_fmdb executeQuery:querySql];
while ([rs next])
{
[resultDic setObject:[rs stringForColumn:@”value”] forKey:[rs stringForColumn:@”key”]];
DLog(@”查询到数据”);
} return resultDic;
}
/*
+ (NSArray )queryData:(NSString )querySql {
if (querySql == nil) { querySql = @"SELECT * FROM t_modals;"; } NSMutableArray *arrM = [NSMutableArray array]; FMResultSet *set = [_fmdb executeQuery:querySql]; while ([set next]) { NSString *name = [set stringForColumn:@"name"]; NSString *age = [set stringForColumn:@"age"]; NSString *ID_No = [set stringForColumn:@"ID_No"]; LVModel *modal = [LVModel modalWith:name age:age.intValue no:ID_No.intValue]; [arrM addObject:modal]; } return arrM;
}
*/
+(BOOL)deleteDataTableWithKey:(NSString *)keyStr
{
//NSString *sqlStr=;
return [_fmdb executeUpdate:@”DELETE FROM t_modals WHERE key=?”,keyStr];
}
/*
+ (BOOL)deleteData:(NSString *)deleteSql {
if (deleteSql == nil) { deleteSql = @"DELETE FROM t_modals"; } return [_fmdb executeUpdate:deleteSql];
}
*/
+(BOOL)modifyData:(NSString )valueStr key:(NSString )keyStr
{
return [_fmdb executeUpdate:@”UPDATE t_modals SET value=? WHERE key=?”,valueStr,keyStr];
}
/*
+ (BOOL)modifyData:(NSString *)modifySql {
if (modifySql == nil) { modifySql = @"UPDATE t_modals SET ID_No = '789789' WHERE name = 'lisi'"; } return [_fmdb executeUpdate:modifySql];
}
*/
@end
相关文章推荐
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 不可修补的 iOS 漏洞可能导致 iPhone 4s 到 iPhone X 永久越狱
- iOS 12.4 系统遭黑客破解,漏洞危及数百万用户
- 每日安全资讯:NSO,一家专业入侵 iPhone 的神秘公司
- [转][源代码]Comex公布JailbreakMe 3.0源代码
- 讲解iOS开发中基本的定位功能实现
- iOS中定位当前位置坐标及转换为火星坐标的方法
- js判断客户端是iOS还是Android等移动终端的方法
- iOS应用开发中AFNetworking库的常用HTTP操作方法小结
- iOS应用中UISearchDisplayController搜索效果的用法
- IOS开发环境windows化攻略
- iOS应用中UITableView左滑自定义选项及批量删除的实现
- iOS中UIAlertView警告框组件的使用教程
- 浅析iOS应用开发中线程间的通信与线程安全问题
- 检测iOS设备是否越狱的方法
- .net平台推送ios消息的实现方法
- 探讨Android与iOS,我们将何去何从?
- Android、iOS和Windows Phone中的推送技术详解