iphone数据存储之-- Core Data的使用(一)


一、概念


1.Core Data 是数据持久化存储的最佳方式


2.数据最终的存储类型可以是:SQLite数据库,XML,二进制,内存里,或自定义数据类型


在Mac OS X 10.5Leopard及以后的版本中,开发者也可以通过继承NSPersistentStore类以创建自定义的存储格式


3.好处:能够合理管理内存,避免使用sql的麻烦,高效


4.构成:


(1)NSManagedObjectContext(被管理的数据上下文)


操作实际内容(操作持久层)


作用:插入数据,查询数据,删除数据


(2)NSManagedObjectModel(被管理的数据模型)


数据库所有表格或数据结构,包含各实体的定义信息


作用:添加实体的属性,建立属性之间的关系


操作方法:视图编辑器,或代码


(3)NSPersistentStoreCoordinator(持久化存储助理)


相当于数据库的连接器


作用:设置数据存储的名字,位置,存储方式,和存储时机


(4)NSManagedObject(被管理的数据记录)


相当于数据库中的表格记录


(5)NSFetchRequest(获取数据的请求)


相当于查询语句


(6)NSEntityDescription(实体结构)


相当于表格结构


(7)后缀为.xcdatamodeld的包


里面是.xcdatamodel文件,用数据模型编辑器编辑


编译后为.momd或.mom文件


5.依赖关系






 


 


二、基于SQLite数据库时,Core Data的简单使用


和SQLite的区别:只能取出整个实体记录,然后分解,之后才能得到实体的某个属性


1.构建流程


包括:创建数据上下文,创建数据模型,创建数据持久化存储助理


(1)若是新建的工程,选择空白应用程序,next






勾选Use Core Data选项






此时生成的工程文件AppDelegate中,会自动生成被管理的数据上下文等相关代码


(2)比如AppDelegate.h文件中,自动生成


@property (readonly, strong, nonatomic) NSManagedObjectContext *managedObjectContext;
@property (readonly, strong, nonatomic) NSManagedObjectModel *managedObjectModel;
@property (readonly, strong, nonatomic) NSPersistentStoreCoordinator *persistentStoreCoordinator;


- (void)saveContext;
- (NSURL *)applicationDocumentsDirectory;
方法saveContext表示:保存数据到持久层(数据库)


方法applicationDocumentsDirectory表示:应用程序沙箱下的Documents目录路径


(例如/var/mobile/Applications/5FG80A45-DFB5-4087-A1B1-41342A977E21/Documents/)


(3)比如AppDelegate.h文件中,自动生成


@synthesize managedObjectContext = __managedObjectContext;
@synthesize managedObjectModel = __managedObjectModel;
@synthesize persistentStoreCoordinator = __persistentStoreCoordinator;
保存数据到持久层


- (void)applicationWillTerminate:(UIApplication *)application
{
    [self saveContext];
}


- (void)saveContext
{
    NSError *error = nil;
    NSManagedObjectContext *managedObjectContext = self.managedObjectContext;
    if (managedObjectContext != nil) {
        if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) {
            NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
            abort();
        } 
    }
}


Documents目录路径


- (NSURL *)applicationDocumentsDirectory
{
    return [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
}
被管理的数据上下文


初始化的后,必须设置持久化存储助理




- (NSManagedObjectContext *)managedObjectContext
{
    if (__managedObjectContext != nil) {
        return __managedObjectContext;
    }
    NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator];
    if (coordinator != nil) {
        __managedObjectContext = [[NSManagedObjectContext alloc] init];
        [__managedObjectContext setPersistentStoreCoordinator:coordinator];
    }
    return __managedObjectContext;
}


 


被管理的数据模型


初始化必须依赖.momd文件路径,而.momd文件由.xcdatamodeld文件编译而来




- (NSManagedObjectModel *)managedObjectModel
{
    if (__managedObjectModel != nil) {
        return __managedObjectModel;
    }
    NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"TestApp" withExtension:@"momd"];
    __managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
    return __managedObjectModel;
}


持久化存储助理


初始化必须依赖NSManagedObjectModel,之后要指定持久化存储的数据类型,默认的是NSSQLiteStoreType,即SQLite数据库;并指定存储路径为Documents目录下,以及数据库名称




- (NSPersistentStoreCoordinator *)persistentStoreCoordinator
{
    if (__persistentStoreCoordinator != nil) {
        return __persistentStoreCoordinator;
    }
    NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"TestApp.sqlite"];


    NSError *error = nil;
    __persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];


    if (![__persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {
        NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
        abort();
    }    
    return __persistentStoreCoordinator;
}


如果不是新工程,也可以自己写入相关代码


(4)此外还生成了TestApp.xcdatamodeld文件


(5)还自动链接了CoreData.framework


(6)在预编译头.pch文件中,加入导入了CoreData.h头文件


#import <CoreData/CoreData.h>
 


2.创建数据模型(数据模型编辑器操作)


(1)创建实体


选中.xcodedatamodel对象






在右边的数据模型编辑器的底部工具栏点击Add Entity添加实体






在最右侧栏对实体命名






(2)创建实体属性


选中实体,点击底部工具栏的Add Attribute添加属性






选中新添加的属性,对属性进行命名,并设置属性的数据类型Attribute Type






(3)为两个实体建立关系


选中一个实体,在底部工具栏点击Add Relationship添加关系






选中新关系,对关系添加名称,目标destination设置为另个实体






(4)建立返回关系


(当你建立一个目标关系,最好建立一个返回关系)


在另一个实体中建立一个关系并命名,设置目标对象为这之前的实体


并在Inverse属性选这之前的关系名称






 


(5)设置两个关系的删除规则Delete Rule,都为关联模式


关联模式cascade:其中一个数据被删除,另一个实体中的数据也会跟着删除






(6)最终两个对象的关系图为






切换Editor Stype按钮






会看到另一种编辑方式:










 3.插入数据


在AppDelegate.m的application:didFinishLaunchingWithOptions:方法里,调用自定义方法


insertCoreData插入数据,代码如下:




- (void)insertCoreData
{
    NSManagedObjectContext *context = [self managedObjectContext];
    
    NSManagedObject *contactInfo = [NSEntityDescription insertNewObjectForEntityForName:@"ContactInfo" inManagedObjectContext:context];
    [contactInfo setValue:@"name B" forKey:@"name"];
    [contactInfo setValue:@"birthday B" forKey:@"birthday"];
    [contactInfo setValue:@"age B" forKey:@"age"];
    
    NSManagedObject *contactDetailInfo = [NSEntityDescription insertNewObjectForEntityForName:@"ContactDetailInfo" inManagedObjectContext:context];
    [contactDetailInfo setValue:@"address B" forKey:@"address"];
    [contactDetailInfo setValue:@"name B" forKey:@"name"];
    [contactDetailInfo setValue:@"telephone B" forKey:@"telephone"];
    
    [contactDetailInfo setValue:contactInfo forKey:@"info"];
    [contactInfo setValue:contactDetailInfo forKey:@"details"];
    
    NSError *error;
    if(![context save:&error])
    {
        NSLog(@"不能保存:%@",[error localizedDescription]);
    }
}


创建数据上下文,调用insertNewObjectForName方法,创建两个数据记录NSManagedObject,然后就可以对之前数据模型编辑视图中定义的属性进行赋值。此时的数据只在内存中被修改,最后调用数据上下文的save方法,保存到持久层


4.查询数据


在调用了insertCoreData之后,可以调用自定的查询方法dataFetchRequest来查询插入的数据




- (void)dataFetchRequest
{
    NSManagedObjectContext *context = [self managedObjectContext];
    NSFetchRequest *fetchRequest = [[[NSFetchRequest alloc] init] autorelease];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"ContactInfo" inManagedObjectContext:context];
    [fetchRequest setEntity:entity];
    NSError *error;
    NSArray *fetchedObjects = [context executeFetchRequest:fetchRequest error:&error];
    for (NSManagedObject *info in fetchedObjects) {
        NSLog(@"name:%@", [info valueForKey:@"name"]);
        NSLog(@"age:%@", [info valueForKey:@"age"]);
        NSLog(@"birthday:%@", [info valueForKey:@"birthday"]);
        NSManagedObject *details = [info valueForKey:@"details"];
        NSLog(@"address:%@", [details valueForKey:@"address"]);
         NSLog(@"telephone:%@", [details valueForKey:@"telephone"]);
    }
}


fetchRequest相当于sql查询语句的包装类,需要用setEntity方法,来指定具体查询的实体结构(表结构)


通过NSEntityDescription的entityForName方法来,返回指向该具体实体结构的指针


然后调用executeFetchRequest:error:方法,来执行查询操作,如果操作成功,则返回对应的数据记录数组


其中,可以通过NSManagedObject数据记录对象里关联的属性,查询另一个数据记录对象里的属性


5.数据模版


为每个实体生成一个NSManagedObject子类


上面设置数据和获取数据时,使用的是Key-Value方式,更好的方法是通过生成强类型的NSManagedObject的子类,通过类的成员属性来访问和获取数据


(1)在数据编辑器视图中选中实体对象,


选则file菜单,点击new,点击file...,选择Core Data项,选择NSManagedObject subclass,生成该实体同名的类,


继承于NSManagedObject






生成对应的ContactInfo.h文件




#import <Foundation/Foundation.h>
#import <CoreData/CoreData.h>


@class ContactDetailInfo;


@interface ContactInfo : NSManagedObject


@property (nonatomic, retain) NSString * age;
@property (nonatomic, retain) NSString * birthday;
@property (nonatomic, retain) NSString * name;
@property (nonatomic, retain) ContactDetailInfo *details;


@end


和ContactInfo.m文件


其中,@dynamic告诉编译器不做处理,使编译通过,其getter和setter方法会在运行时动态创建,由Core Data框架为此类属性生成存取方法




#import "ContactInfo.h"
#import "ContactDetailInfo.h"




@implementation ContactInfo


@dynamic age;
@dynamic birthday;
@dynamic name;
@dynamic details;


@end


以及ContactDetailInfo.h文件




#import <Foundation/Foundation.h>
#import <CoreData/CoreData.h>


@class ContactInfo;


@interface ContactDetailInfo : NSManagedObject


@property (nonatomic, retain) NSString * address;
@property (nonatomic, retain) NSString * name;
@property (nonatomic, retain) NSString * telephone;
@property (nonatomic, retain) ContactInfo *info;


@end


和ContactDetailInfo.m文件




#import "ContactDetailInfo.h"
#import "ContactInfo.h"




@implementation ContactDetailInfo


@dynamic address;
@dynamic name;
@dynamic telephone;
@dynamic info;


@end


此时,数据模型编辑器视图最右边栏中,实体的class就变成具体的类名






之前用Key-Value的代码就可以修改为:


#import "ContactInfo.h"
#import "ContactDetailInfo.h"


- (void)insertCoreData
{
    NSManagedObjectContext *context = [self managedObjectContext];
    
    ContactInfo *contactInfo = [NSEntityDescription insertNewObjectForEntityForName:@"ContactInfo" inManagedObjectContext:context];
    contactInfo.name = @"name B";
    contactInfo.birthday = @"birthday B";
    contactInfo.age = @"age B";
    
    ContactDetailInfo *contactDetailInfo = [NSEntityDescription insertNewObjectForEntityForName:@"ContactDetailInfo" inManagedObjectContext:context];
    contactDetailInfo.address = @"address B";
    contactDetailInfo.name = @"name B";
    contactDetailInfo.telephone = @"telephone B";
    
    contactDetailInfo.info = contactInfo;
    contactInfo.details = contactDetailInfo;
    
    NSError *error;
    if(![context save:&error])
    {
        NSLog(@"不能保存:%@",[error localizedDescription]);
    }
}




- (void)dataFetchRequest
{
    NSManagedObjectContext *context = [self managedObjectContext];
    NSFetchRequest *fetchRequest = [[[NSFetchRequest alloc] init] autorelease];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"ContactInfo" inManagedObjectContext:context];
    [fetchRequest setEntity:entity];
    NSError *error;
    NSArray *fetchedObjects = [context executeFetchRequest:fetchRequest error:&error];
    for (ContactInfo *info in fetchedObjects) {
        
        NSLog(@"name:%@", info.name);
        NSLog(@"age:%@", info.age);
        NSLog(@"birthday:%@", info.birthday);
        ContactDetailInfo *details = info.details;
        NSLog(@"address:%@", details.address);
         NSLog(@"telephone:%@", details.telephone);
    }
}


 


三、数据库相关


1.打印隐藏的sql语句:


在Edit Scheme中选择Run,之后进入Arguments标签,添加参数:“-com.apple.CoreData.SQLDebug 1”


2.使用SQLite存储时,数据库结构


存储的SQLite数据库表名称:大写“Z”加上实体名称大写,一个实体相当于一张表


具体的字段名称:大写“Z”加上实体属性名称大写






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自动控制节水灌溉技术的高低代表着农业现代化的发展状况,灌溉系统自动化水平较低是制约我国高效农业发展的主要原因。本文就此问题研究了单片机控制的滴灌节水灌溉系统,该系统可对不同土壤的湿度进行监控,并按照作物对土壤湿度的要求进行适时、适量灌水,其核心是单片机和PC机构成的控制部分,主要对土壤湿度与灌水量之间的关系、灌溉控制技术及设备系统的硬件、软件编程各个部分进行了深入的研究。 单片机控制部分采用上下位机的形式。下位机硬件部分选用AT89C51单片机为核心,主要由土壤湿度传感器,信号处理电路,显示电路,输出控制电路,故障报警电路等组成,软件选用汇编语言编程。上位机选用586型以上PC机,通过MAX232芯片实现同下位机的电平转换功能,上下位机之间通过串行通信方式进行数据的双向传输,软件选用VB高级编程语言以建立友好的人机界面。系统主要具有以下功能:可在PC机提供的人机对话界面上设置作物要求的土壤湿度相关参数;单片机可将土壤湿度传感器检测到的土壤湿度模拟量转换成数字量,显示于LED显示器上,同时单片机可采用串行通信方式将此湿度值传输到PC机上;PC机通过其内设程序计算出所需的灌水量和灌水时间,且显示于界面上,并将有关的灌水信息反馈给单片机,若需灌水,则单片机系统启动鸣音报警,发出灌水信号,并经放大驱动设备,开启电磁阀进行倒计时定时灌水,若不需灌水,即PC机上显示的灌水量和灌水时间均为0,系统不进行灌水。
智慧农业是一种结合了现代信息技术,包括物联网、大数据、云计算等,对农业生产过程进行智能化管理和监控的新模式。它通过各种传感器和设备采集农业生产中的关键数据,如大气、土壤和水质参数,以及生物生长状态等,实现远程诊断和精准调控。智慧农业的核心价值在于提高农业生产效率,保障食品安全,实现资源的可持续利用,并为农业产业的转型升级提供支持。 智慧农业的实现依赖于多个子系统,包括但不限于设施蔬菜精细化种植管理系统、农业技术资料库、数据采集系统、防伪防串货系统、食品安全与质量追溯系统、应急追溯系统、灾情疫情防控系统、农业工作管理系统、远程诊断系统、监控中心、环境监测系统、智能环境控制系统等。这些系统共同构成了一个综合的信息管理和服务平台,使得农业生产者能够基于数据做出更加科学的决策。 数据采集是智慧农业的基础。通过手工录入、传感器自动采集、移动端录入、条码/RFID扫描录入、拍照录入以及GPS和遥感技术等多种方式,智慧农业系统能够全面收集农业生产过程中的各种数据。这些数据不仅包括环境参数,还涵盖了生长状态、加工保存、检验检疫等环节,为农业生产提供了全面的数据支持。 智慧农业的应用前景广阔,它不仅能够提升农业生产的管理水平,还能够通过各种应用系统,如库房管理、无公害监控、物资管理、成本控制等,为农业生产者提供全面的服务。此外,智慧农业还能够支持政府监管,通过发病报告、投入品报告、死亡报告等,加强农业产品的安全管理和质量控制。 面对智慧农业的建设和发展,存在一些挑战,如投资成本高、生产过程标准化难度大、数据采集和监测的技术难题等。为了克服这些挑战,需要政府、企业和相关机构的共同努力,通过政策支持、技术创新和教育培训等手段,推动智慧农业的健康发展。智慧农业的建设需要明确建设目的,选择合适的系统模块,并制定合理的设备布署方案,以实现农业生产的智能化、精准化和高效化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值