数据库和3G的结合使用
//
// 设备数据管理类
#import <Foundation/Foundation.h>
#import "DeviceInfo.h"
@interface DeviceDataManager : NSObject
{
NSMutableArray *dataArray;
}
+(DeviceDataManager *)instance;
-(NSMutableArray *)allDeviceData;//返回所有本地存储的设备
-(DeviceInfo *)getDeviceInfoWith:(NSString *)mac;//根据mac地址返回该设备的信息
-(BOOL)insertOrReqlaceSignalDevice:(DeviceInfo *)devInfo;//插入或修改指定的设备信息
-(BOOL)deleteDeviceWith:(NSString *)mac;//删除指定mac地址的设备
@end
//
// DeviceDataManager.m
// SmartHomeWIFI
//
// Created by 深圳市 秀软科技有限公司 on 14-2-20.
// Copyright (c) 2014年 huhuaxiang. All rights reserved.
//
#import "DeviceDataManager.h"
#import "SQLdataManger.h"
static DeviceDataManager *devInfoManager;
@implementation DeviceDataManager
-(id)init
{
if(self=[superinit])
{
}
returnself;
}
+(DeviceDataManager *)instance
{
if(!devInfoManager)
devInfoManager=[[DeviceDataManageralloc]init];
returndevInfoManager;
}
-(NSMutableArray *)allDeviceData
{
if(!dataArray||dataArray.count<1)
[selfdataArrayInit];
returndataArray;
}
-(DeviceInfo *)getDeviceInfoWith:(NSString *)mac
{
for (DeviceInfo *info indataArray) {
if([info.mac isEqualToString:mac])
return info;
}
returnnil;
}
-(BOOL)insertOrReqlaceSignalDevice:(DeviceInfo *)devInfo
{
if(!devInfo)return NO;
BOOL flag=[[SQLdataMangerinstance]insertOrReqlaceSignalDevice:devInfo];
if(flag)
{
//如果存在则删除原来的,更新现在的
DeviceInfo *info;
BOOL exite=NO;
for (int i=0; i<dataArray.count; i++) {
info=[dataArray objectAtIndex:i];
if([info.mac isEqualToString:devInfo.mac])
{
info=devInfo;
exite=YES;
}
}
if(!exite)
[dataArray addObject:devInfo];
}
return flag;
}
-(BOOL)deleteDeviceWith:(NSString *)mac
{
BOOL flag=[[SQLdataMangerinstance]deleteTableDataWithMAC:mac];
if(flag)
{
for (DeviceInfo *info in dataArray) {
if([info.mac isEqualToString:mac])
[dataArray removeObject:info];
}
}
return flag;
}
-(void)dataArrayInit
{
NSArray *dataA=[[SQLdataMangerinstance]queryDeviceInfoTable];
dataArray=[[NSMutableArrayalloc]initWithArray:dataA];
}
@end
数据库和3G的结合使用的更多相关文章
- 利用Navicat高效率postgresql转mysql数据库
本人很喜欢postgresql数据库,也一直认为postgresql比mysql要更好更强大. 可生态环境太差了,无奈,最近要把一个小站转成mysql数据库. 小站主要表数据110万,pg_dump备 ...
- 织梦cms PHPcms 帝国cms比较
现在建网站不需要请程序员从基础的程序开发做起了,有专业的建站工具,CMS是使用最广泛的建站工具.CMS是Content Management System 现在建网站不需要请程序员从基础的程序开发做起 ...
- 对帝国cms、dedecms、phpcms等负载测试总结
来自:http://www.chinaz.com/web/2013/0729/311360.shtml 担心被骂,本不想写这篇文章.犹豫良久,最终还是决定写.希望能够帮助到一些朋友,认识到数据库索引正 ...
- JSP应用开发 -------- 电纸书(未完待续)
http://www.educity.cn/jiaocheng/j9415.html JSP程序员常用的技术 第1章 JSP及其相关技术导航 [本章专家知识导学] JSP是一种编程语言,也是一种动 ...
- EF里查看/修改实体的当前值、原始值和数据库值以及重写SaveChanges方法记录实体状态
本文目录 查看实体当前.原始和数据库值:DbEntityEntry 查看实体的某个属性值:GetValue<TValue>方法 拷贝DbPropertyValues到实体:ToObject ...
- MVC Code First 自动生成数据库
1.新建一个MVC项目
- TPC-H生成.tbl文件导入postgresql数据库的坑
数据库project好好的不用主流的MySQL和Microsoft server而要求用听都没听过的postgresql (当然,可能你三个都没听过) 这里的坑主要是把生成的那八张.tbl的表导入pg ...
- IP地址数据库-ISP运营商列表(2017年1月)
IP地址数据库 微信号:qqzeng-ip [全球旗舰版][国内精华版][国外拓展版][英文版][掩码版] http://qqzeng.com 中国大陆:三大基础运营商 中国电信中国联通中国 ...
- Hibernate映射文件创建和删除触发器,存储过程等数据库对象
创建表,触发器,和存储过程等数据库对象,这里一定要用create 在hibernate.cfg.xml文件中
随机推荐
- C——malloc & free(转载自bccn C语言论坛)
原帖及讨论:http://bbs.bccn.net/thread-82212-1-1.html 原文链接:http://www.bccn.net/Article/kfyy/cyy/jszl/20060 ...
- 基础篇-初步认识PE格式
1 PE(Portable Executable)格式,是Win32环境可移植可执行文件(如exe.dll.vxd.sys和vdm等)的标准文件格式.PE格式衍生于早期建立在VAX(R)VMS(R)上 ...
- Java集合类学习笔记(各种Map实现类的性能分析)
HashMap和Hashtable的实现机制几乎一样,但由于Hashtable是一个古老的.线程安全的集合,因此HashMap通常比Hashtable要快. TreeMap比HashMap和Hasht ...
- LeetCode 5 Longest Palindromic Substring manacher算法,最长回文子序列,string.substr(start,len) 难度:2
https://leetcode.com/problems/longest-palindromic-substring/ manacher算法相关:http://blog.csdn.net/ywhor ...
- C++ 知道虚函数表的存在
今天翻看陈皓大大的博客,直接找关于C++的东东,看到了虚函数表的内容,找一些能看得懂的地方记下笔记. 0 引子 类中存在虚函数,就会存在虚函数表,在vs2015的实现中,它存在于类的头部. 假设有如下 ...
- JavaScript 字符串常用操作
JavaScript 字符串用于存储和处理文本.因此在编写 JS 代码之时她总如影随形,在你处理用户的输入数据的时候,在读取或设置 DOM 对象的属性时,在操作 Cookie 时,在转换各种不同 Da ...
- js数组去重的方法
//数组去重 Array.prototype.unique = function() { var newArr = [], hash = {}; for(var i=0, len=this.lengt ...
- android学习之RadioButton和CheckBox
移通152 余继彪 RadioBuuton是一个单选按钮,CheckBox是一个复选按钮 . RadioButton的使用 ,首先要将RadioButton放在RadioGroup中,RadioGro ...
- 006-Map、Tuple、Zip实战解析
006-Map.Tuple.Zip实战解析 实战代码 Map实战 本身是映射,映射关系在实际中应用非常广泛,比如:配置信息都是Key-Value形式 键值对不存在下边关系 是一个immutable(不 ...
- 查询SQLSERVER执行过的SQL记录
SELECT TOP 1000 --创建时间 QS.creation_time, --查询语句 SUBSTRING(ST.text,(QS.statement_start_offset/2)+1, ( ...