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()
}
}
Core Data数据操作的更多相关文章
- Core Data(数据持久化)
Core Data可能是OS X和iOS中最容易被误解的框架之一了.为了帮助大家理解,我们将快速研究Core Data,来看一下它是关于什么的.为了正确使用Core Data, 有必要理解其概念.几乎 ...
- Core Data数据持久性存储基础教程-备用
摘要 就像我一直说的,Core Data是iOS编程,乃至Mac编程中使用持久性数据存储的最佳方式,本质上来说,Core Data使用的就是SQLite,但是通过一系列特性避免了使用SQL的一些列的麻 ...
- iOS教程:Core Data数据持久性存储基础教程
目录[-] 创建Core Data工程 创建数据模型 测试我们的数据模型 来看看SQL语句的真面目 自动生成的模型文件 创建一个表视图 之后看些什么? 就像我一直说的,Core Data是iOS编程, ...
- Core Data 基本数据操作 增删改查 排序
所有操作都基于Core Data框架相关 API,工程需要添加CoreData.framework支持 1.增 NSEntityDescription insertNewObjectForEntit ...
- Core Data 数据出现Fault
I am mapping Json Data from Server using Restkit and I am Displaying those data by fetching from db. ...
- 在.net core中数据操作的两种方式(Db first && Code first)
在开发过程中我们通常使用的是Db first这种模式,而在.net core 中推荐使用的却是 code first 反正我是很不习惯这种开发模式 于是就搜寻整个微软的官方文档,终于找到了有关.net ...
- iOS开发中的4种数据持久化方式【二、数据库 SQLite3、Core Data 的运用】
在上文,我们介绍了ios开发中的其中2种数据持久化方式:属性列表.归档解档.本节将继续介绍另外2种iOS持久化数据的方法:数据库 SQLite3.Core Data 的运 ...
- iOS开发——数据持久化Swift篇&使用Core Data进行数据持久化存储
使用Core Data进行数据持久化存储 一,Core Data介绍 1,Core Data是iOS5之后才出现的一个数据持久化存储框架,它提供了对象-关系映射(ORM)的功能,即能够将对象转化成 ...
- 四种数据持久化方式(下) :SQLite3 和 Core Data
在上文,我们介绍了iOS开发中的其中2种数据持久化方式:属性列表.归档解档. 本节将继续介绍另外2种iOS持久化数据的方法:数据库 SQLite3.Core Data 的运用: 在本节,将通过对4个文 ...
随机推荐
- 6/14 sprint2 看板和燃尽图的更新
看板: 燃尽图: 例会照: 总结:因为最近刚好碰上端午假期,再加上程序出了点问题,所以导致进度有点慢, 但是我们还是很努力地在找资料把问题给解决了,虽然完成的情况有点不如人意, 但是我们付出的努力还是 ...
- nodejs+express+jade+mongodb给我baby做个小相册(2)-留言板
上一篇简单的实现了下照片的展现跟浏览功能,这一篇我将给这个程序添加一个留言的功能.那么留言的话肯定要涉及到数据持久了,其实对于这个小功能的话,用个xml就可以,不过为了看起来更加高大上,我决定使用mo ...
- ompparticles.cpp:(.text+0x322): undefined reference to `omp_set_num_threads'
参考 http://www.code-by.org/viewtopic.php?f=54&t=163
- JAVA - 大数类详解
写在前面 对于ACMer来说,java语言最大的优势就是BigInteger,Bigdecimal,String三个类. 这三个类分别是高精度整数,高精度浮点数和字符串,之所以说这个是它的优势是因为j ...
- f4: Facebook’s Warm BLOB Storage System——Erasure Code
Facebook在OSDI 2014上发表论文f4: Facebook's Warm BLOB Storage System,这个系统主要目的就是降低存储成本,在容忍磁盘,主机,机架,数据中心的同时提 ...
- 【JavaScript回顾】对象创建的几种模式
组合使用构造函数模式和原型模式 创建自定义类型的常见方式,就是组合使用构造函数模式与原型模式.构造函数模式用于定义实 例属性,而原型模式用于定义方法和共享的属性.结果,每个实例都会有自己的一份实例属性 ...
- ActiveReports 报表应用教程 (7)---交叉报表及数据透视图实现方案
在 ActiveReports 中可以通过矩阵控件非常方便的实现交叉报表,同时还可以设置数据的分组.排序.过滤.小计.合计等操作,可以满足您报表的智能数据分析等需求.在矩阵控件中组的行数和列数由每个行 ...
- 金山快盘有Linux版了
似乎是2013-09-29最早发出的新闻. 怎么会没有一点传播呢,难道这么不招待见吗? 出品方是中科麒麟. http://www.ubuntukylin.com/applications/showim ...
- 那一夜,我们..奋笔疾书敲出的--->>库存管理系统
说了会再见,最近好吗?无论你在哪里>也许你在温暖的家,或许你在身在异乡的城市;或许你高高的峰顶放生高歌,或许你还在陡峭的山峰半空努力攀爬.......相信我们都会登上顶峰,"会当凌绝顶 ...
- 关于网络上的各种mysql性能测试结论
关于网上的各种性能测试帖子,我想说以下几点: 1.为了使性能测试更加的客观.实际,应该说明针对什么场景进行测试,查询.还是修改,是否包含了主键,包含了几个索引,各自的差别是什么.因为不同的mysql分 ...