Core Data数据操作

1.建立学生实体,插入100条数据

2.按条件查询学生数据

3.统计学生信息

4.修改学生信息

5.删除学生数据

import UIKit

import CoreData

class ViewController: UIViewController {

override func viewDidLoad() {

super.viewDidLoad()

//1.建立模型文件

//2.建立CoreDataStack

//3.设置AppDelegate

//插入数据

insertStudents()

//查询数据

fetchStudents()

//统计信息

countStudents()

//修改数据

updateStudents()

//删除数据

deleteStudents()

}

}

extension ViewController{

func insertStudents(){

let strs1 = ["a","b","c","d","e","f","g","h","i","j"]

let strs2 = ["01","02","03","04","05","06","07","08","09","10"]

for i in 0..<100 {

let sno = "\(1001+i)"

let name = strs1[i/10] + strs2[i%10]

let score = i

insertStudent(sno: sno, name: name, score: score)

}

CoreDataStack.defaultStack().saveContext()

}

func insertStudent(sno sno:String,name:String,score:Int){

let context = CoreDataStack.defaultStack().context

let student = NSEntityDescription.insertNewObjectForEntityForName("student", inManagedObjectContext: context) as! Student

student.sno = sno

student.name = name

student.score = score

}

func fetchStudents(){

let context=CoreDataStack.defaultStack().context

let request=NSFetchRequest(entityName:"Student")

let sort = NSSortDescriptor(key:"sno", ascending:true, selector:"localizedStandardCompare")

request.sortDescriptors = [sort]

//request.predicate = NSPredicate(format:"score > 60")

//request.predicate = NSPredicate(format:"name like ‘a*‘")

do{

let students=(try context.executeFetchRequest(request)) as! [Student]

for student in students{

print("\(student.sno!),\(student.name!),\(student.score!)")

}

}catch{

print("Fetch failed")

}

}

func countStudents(){

//        let context = CoreDataStack.defaultStack().context

//

//        let request = NSFetchRequest(entityName:"Student")

//        request.predicate = NSPredicate(format:"score > 90")

//        request.resultType = CountResultType

//

//        do {

//            let entries = (try context.executeFetchRequest(request))

//            let count = entries.first!.integerValue

//            print("Count:\(count)")

//        }catch{

//            print("Fetch failed......")

//        }

let context = CoreDataStack.defaultStack().context

let request=NSFetchRequest(entityName:"Student")

request.resultType = .DictionaryResultType

let description = NSExpressionDescription()

description.name="AverageScore"

let args=[NSExpression(forKeyPath:"score")]

description.expression = NSExpression(forFunction: "average", arguments:args)

description.expressionResultType = .FloatAttributeType

do {

let entries = (try context.executeFetchRequest(request))

let result=entries.first! as! NSDictionary

let averageScore = result["AverageScore"]!

print("Average:\(averageScore)")

}catch{

print("Fetch failed......")

}

}

func updateStudents(){

let context=CoreDataStack.defaultStack().context

let request = NSFetchRequest(entityName:"Student")

request.predicate = NSPredicate(format:"name like ‘a*‘")

do{

let students = (try context.executeFetchRequest(request)) as! [Student]

for student in students{

student.score = 100

}

}catch{

print("Fetch failed")

}

CoreDataStack.defaultStack().saveContext()

}

func deleteStudents(){

let context = CoreDataStack.defaultStack().context

let request=NSFetchRequest(entityName:"Student")

request.predicate = NSPredicate(format:"score < 60")

do{

let students = (try context.executeFetchRequest(request)) as! [Student]

for student in students{

context.deleteObject(student)

}

}catch{

print("Fetch failed......")

}

CoreDataStack.defaultStack().saveContext()

}

}

时间: 2024-10-14 20:59:00

Core Data数据操作的相关文章

Core Data 数据操作 增删改查

所有操作都基于Core Data框架相关 API,工程需要添加CoreData.framework支持 1.增  NSEntityDescription insertNewObjectForEntityForName: inManagedObjectContext: 利用NSEntityDescription工厂方法创建Entity AppDelegate *appDelegate = [UIApplication sharedApplication].delegate; //get NSMan

iOS Core Data 数据迁移 指南

前言 Core Data是iOS上一个效率比较高的数据库框架,(但是Core Data并不是一种数据库,它底层还是利用Sqlite3来存储数据的),它可以把数据当成对象来操作,而且开发者并不需要在乎数据在磁盘上面的存储方式.它会把位于NSManagedObject Context里面的托管对象NSManagedObject类的实例或者某个NSManagedObject子类的实例,通过NSManagedObjectModel托管对象模型,把托管对象保存到持久化存储协调器NSPersistentSt

iOS教程:Core Data数据持久性存储基础教程

其实最近更多的是在写这篇文章<iOS教程:使用持久性数据Core Data>,这篇是<iOS开发教程:Storyboard全解析-第一部分>这篇的后续,但是目前还没有完成,先放出一个持久性数据存储的教程以供参考.这其实是一篇翻译文章,英文的原文见这里.我翻译的过程中改变了一些内容以便适应我们中国人的口味,下面请看教程: 就像我一直说的,Core Data是iOS编程,乃至Mac编程中使用持久性数据存储的最佳方式,本质上来说,Core Data使用的就是SQLite,但是通过一系列特

Swift - 使用Core Data进行数据持久化存储

一,Core Data介绍 1,Core Data是iOS5之后才出现的一个数据持久化存储框架,它提供了对象-关系映射(ORM)的功能,即能够将对象转化成数据,也能够将保存在数据库中的数据还原成对象. 2,虽然其底层也是由类似于SQL的技术来实现,但我们不需要编写任何SQL语句,有点像Java开发中的Hibernate持久化框架 3,Core Data数据最终的存储类型可以是:SQLite数据库,XML,二进制,内存里,或自定义数据类型. 4,与SQLite区别:只能取出整个实体记录,然后分解,

ios开发中的4种数据持久化方式【二、数据库 SQLite3、Core Data 的运用】

               在上文,我们介绍了ios开发中的其中2种数据持久化方式:属性列表.归档解档.本节将继续介绍另外2种iOS持久化数据的方法:数据库 SQLite3.Core Data 的运用: 在本节,将通过对4个文本框内容的创建.修改,退出后台,再重新回到后台,来认识这两种持久化数据的方式.效果图如下[图1]: [图1 GUI界面效果图] [本次开发环境: Xcode:7.2     iOS Simulator:iphone6S plus   By:啊左]     一.数据库SQL

iOS教程:如何使用Core Data – 预加载和引入数据

这是接着上一次<iOS教程:Core Data数据持久性存储基础教程>的后续教程,程序也会使用上一次制作完成的. 再上一个教程中,我们只做了一个数据模型,之后我们使用这个数据模型中的数据创建了一个表视图,我们还学习了如何测试数据模型的可行性,今天,我们来看看如何在应用启动的时候,将已经存在的数据载入或者引用到我们的程序中去. 请注意我们在上一次的教程中学习到的是直接通过操作SQLite数据库来加载数据,你当然可以一直使用这种方法,但是这个教程教授的方法更加优雅,更加合理. 在下一部分的教程中,

iOS Swift学习笔记 Core Data (一)Hello Core Data

正在学习swift的Core Data,做个笔记,顺便分享源码 这个实例是一个很简单的Table,通过右上角的Add按钮可以添加新的用户名.数据存储在CoreData中,这样,才不会丢失. 通过这个例子可以学会: 使用Xcode的model编辑器创建数据对象的model data. 添加新的记录到CoreData中 从CoreData中获取记录集合 显示记录到table view中 这个例子十分简单,还有很多可以改进的地方,比如,每次要操作managed class都需要访问AppDelegat

Core Data中的多线程之二

在Core Data中使用多线程一般不是为了能够提高性能和效率,而是为了使主线程能够不被阻塞,使能够在做其他数据操作的时候,UI还能够继续响应用户的行为.当执行fetch操作时,Core Data系统会根据需要自动开启多个线程做相应的操作,因此我们自己添加多线程并不能提高效率,而仅仅是为了能够将主线程丛繁重的数据操作中解脱出来. 苹果官方文档中对Core Data并发操作的说明: Concurrency with Core Data: 1.Use Thread Confinement to Su

Core Data 教学

看了一篇国外的文章,关于iOS9的Core Data教学,在这里做了一下总结 Core Data 教学 示例开源地址:LastDayCoreData 在这篇文章中我们将学习Core Data的系列教程,你将使用Swift2.0写你的Core Data.你将发现在Xcode中它是很容易上手的,从启动代码导师数据模型编辑器.在教程结束后,你会了解到: 使用Xcode的model editor将你想存储在Core Data. 添加新的记录到 Core Data 从Core Data中读取一组数据 在表