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数据操作的更多相关文章

  1. Core Data(数据持久化)

    Core Data可能是OS X和iOS中最容易被误解的框架之一了.为了帮助大家理解,我们将快速研究Core Data,来看一下它是关于什么的.为了正确使用Core Data, 有必要理解其概念.几乎 ...

  2. Core Data数据持久性存储基础教程-备用

    摘要 就像我一直说的,Core Data是iOS编程,乃至Mac编程中使用持久性数据存储的最佳方式,本质上来说,Core Data使用的就是SQLite,但是通过一系列特性避免了使用SQL的一些列的麻 ...

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

    目录[-] 创建Core Data工程 创建数据模型 测试我们的数据模型 来看看SQL语句的真面目 自动生成的模型文件 创建一个表视图 之后看些什么? 就像我一直说的,Core Data是iOS编程, ...

  4. Core Data 基本数据操作 增删改查 排序

    所有操作都基于Core Data框架相关 API,工程需要添加CoreData.framework支持 1.增  NSEntityDescription insertNewObjectForEntit ...

  5. Core Data 数据出现Fault

    I am mapping Json Data from Server using Restkit and I am Displaying those data by fetching from db. ...

  6. 在.net core中数据操作的两种方式(Db first && Code first)

    在开发过程中我们通常使用的是Db first这种模式,而在.net core 中推荐使用的却是 code first 反正我是很不习惯这种开发模式 于是就搜寻整个微软的官方文档,终于找到了有关.net ...

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

                   在上文,我们介绍了ios开发中的其中2种数据持久化方式:属性列表.归档解档.本节将继续介绍另外2种iOS持久化数据的方法:数据库 SQLite3.Core Data 的运 ...

  8. iOS开发——数据持久化Swift篇&使用Core Data进行数据持久化存储

    使用Core Data进行数据持久化存储   一,Core Data介绍 1,Core Data是iOS5之后才出现的一个数据持久化存储框架,它提供了对象-关系映射(ORM)的功能,即能够将对象转化成 ...

  9. 四种数据持久化方式(下) :SQLite3 和 Core Data

    在上文,我们介绍了iOS开发中的其中2种数据持久化方式:属性列表.归档解档. 本节将继续介绍另外2种iOS持久化数据的方法:数据库 SQLite3.Core Data 的运用: 在本节,将通过对4个文 ...

随机推荐

  1. 一、HTTPServer,RequestHandler,ServerHandler,Handler

    1.      HTTPServer,RequestHandler,ServerHandler,Handler 1.1       基本概念 HTTPServer主要是对传输控制层HTTP,TCP,S ...

  2. Tempdb的并发阻塞

    9.3 Tempdb的并发阻塞 在介绍Tempdb的并发问题前,先介绍几个比较特殊的数据页. PFS(Page Free Space),用于标识数据页空间的使用情况,以字节标识,可以表示数据页使用百分 ...

  3. 后缀数组(模板题) - 求最长公共子串 - poj 2774 Long Long Message

    Language: Default Long Long Message Time Limit: 4000MS   Memory Limit: 131072K Total Submissions: 21 ...

  4. jQuery回调函数

    1.引言 今天在学习<jQuery基础教程>在学习编写插件的时候,书中说利用回调函数来当参数,会极大的提高程序的灵活性.对回调函数很陌生.研究了一下给的示例程序.感觉对回调函数有了基本的了 ...

  5. SQL Server 性能调优(一)——从等待状态判断系统资源瓶颈【转】

    转载自:http://blog.csdn.net/dba_huangzj/article/details/7607844#comments 通过DMV查看当时SQL SERVER所有任务的状态(sle ...

  6. No.011:Container With Most Water

    问题: Given n non-negative integers a1, a2, ..., an, where each represents a point at coordinate (i, a ...

  7. (旧)子数涵数·UI设计——扁平化设计

    一.基本资料 1.由来 扁平化设计这个概念,是由Google(谷歌)在2008年提出的:它的首个实践者是microsoft(微软),microsoft在2012年发行了win8系统,这个系统的外观主题 ...

  8. 那些教程没有的php4-composer依赖管理工具

    phpcomposer PHP 5.3.2+ Composer 不是一个包管理器,但它在每个项目的基础上进行管理,在你项目的某个目录中(例如 vendor)进行安装.默认情况下它不会在全局安装任何东西 ...

  9. New Valid Tracking Metric Now Available in Seller Central

    On July 7, Amazon added Valid Tracking Rate as a new metric in Seller Central. This metric shows the ...

  10. swift学习笔记之-自动引用计数

    //自动引用计数 import UIKit /*自动引用计数(Automatic Reference Counting) 防止循环强引用 Swift 使用自动引用计数(ARC)机制来跟踪和管理你的应用 ...