//

//  设备数据管理类

#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的结合使用的更多相关文章

  1. 利用Navicat高效率postgresql转mysql数据库

    本人很喜欢postgresql数据库,也一直认为postgresql比mysql要更好更强大. 可生态环境太差了,无奈,最近要把一个小站转成mysql数据库. 小站主要表数据110万,pg_dump备 ...

  2. 织梦cms PHPcms 帝国cms比较

    现在建网站不需要请程序员从基础的程序开发做起了,有专业的建站工具,CMS是使用最广泛的建站工具.CMS是Content Management System 现在建网站不需要请程序员从基础的程序开发做起 ...

  3. 对帝国cms、dedecms、phpcms等负载测试总结

    来自:http://www.chinaz.com/web/2013/0729/311360.shtml 担心被骂,本不想写这篇文章.犹豫良久,最终还是决定写.希望能够帮助到一些朋友,认识到数据库索引正 ...

  4. JSP应用开发 -------- 电纸书(未完待续)

    http://www.educity.cn/jiaocheng/j9415.html JSP程序员常用的技术   第1章 JSP及其相关技术导航 [本章专家知识导学] JSP是一种编程语言,也是一种动 ...

  5. EF里查看/修改实体的当前值、原始值和数据库值以及重写SaveChanges方法记录实体状态

    本文目录 查看实体当前.原始和数据库值:DbEntityEntry 查看实体的某个属性值:GetValue<TValue>方法 拷贝DbPropertyValues到实体:ToObject ...

  6. MVC Code First 自动生成数据库

    1.新建一个MVC项目

  7. TPC-H生成.tbl文件导入postgresql数据库的坑

    数据库project好好的不用主流的MySQL和Microsoft server而要求用听都没听过的postgresql (当然,可能你三个都没听过) 这里的坑主要是把生成的那八张.tbl的表导入pg ...

  8. IP地址数据库-ISP运营商列表(2017年1月)

    IP地址数据库  微信号:qqzeng-ip [全球旗舰版][国内精华版][国外拓展版][英文版][掩码版]     http://qqzeng.com 中国大陆:三大基础运营商 中国电信中国联通中国 ...

  9. Hibernate映射文件创建和删除触发器,存储过程等数据库对象

    创建表,触发器,和存储过程等数据库对象,这里一定要用create 在hibernate.cfg.xml文件中

随机推荐

  1. C——malloc & free(转载自bccn C语言论坛)

    原帖及讨论:http://bbs.bccn.net/thread-82212-1-1.html 原文链接:http://www.bccn.net/Article/kfyy/cyy/jszl/20060 ...

  2. 基础篇-初步认识PE格式

    1 PE(Portable Executable)格式,是Win32环境可移植可执行文件(如exe.dll.vxd.sys和vdm等)的标准文件格式.PE格式衍生于早期建立在VAX(R)VMS(R)上 ...

  3. Java集合类学习笔记(各种Map实现类的性能分析)

    HashMap和Hashtable的实现机制几乎一样,但由于Hashtable是一个古老的.线程安全的集合,因此HashMap通常比Hashtable要快. TreeMap比HashMap和Hasht ...

  4. LeetCode 5 Longest Palindromic Substring manacher算法,最长回文子序列,string.substr(start,len) 难度:2

    https://leetcode.com/problems/longest-palindromic-substring/ manacher算法相关:http://blog.csdn.net/ywhor ...

  5. C++ 知道虚函数表的存在

    今天翻看陈皓大大的博客,直接找关于C++的东东,看到了虚函数表的内容,找一些能看得懂的地方记下笔记. 0 引子 类中存在虚函数,就会存在虚函数表,在vs2015的实现中,它存在于类的头部. 假设有如下 ...

  6. JavaScript 字符串常用操作

    JavaScript 字符串用于存储和处理文本.因此在编写 JS 代码之时她总如影随形,在你处理用户的输入数据的时候,在读取或设置 DOM 对象的属性时,在操作 Cookie 时,在转换各种不同 Da ...

  7. js数组去重的方法

    //数组去重 Array.prototype.unique = function() { var newArr = [], hash = {}; for(var i=0, len=this.lengt ...

  8. android学习之RadioButton和CheckBox

    移通152 余继彪 RadioBuuton是一个单选按钮,CheckBox是一个复选按钮 . RadioButton的使用 ,首先要将RadioButton放在RadioGroup中,RadioGro ...

  9. 006-Map、Tuple、Zip实战解析

    006-Map.Tuple.Zip实战解析 实战代码 Map实战 本身是映射,映射关系在实际中应用非常广泛,比如:配置信息都是Key-Value形式 键值对不存在下边关系 是一个immutable(不 ...

  10. 查询SQLSERVER执行过的SQL记录

    SELECT TOP 1000 --创建时间 QS.creation_time, --查询语句 SUBSTRING(ST.text,(QS.statement_start_offset/2)+1, ( ...