IOS CoreData 简单使用CURD
2015-04-19 21:13
323 查看
iOS在CoreData中简单封装了SQLite,让开发者不需要写sql语句就可以使用SQLite进行CURD操作。
要使用CoreData切记在创建项目的时候选中CoreData选项。
在操作SQLite的时候最终要的是获得一个NSManagedObjectContext对象,这个对象在AppDelegate中可以获得,而AppDelegate实例可以在UIApplication中获得,swift获得NSManagedObjectContext对象的实现可以这样写
SQLite中的每一条数据封装在NSManagedObject中,每一条数据都是一个NSManagedObject示例
下面的示例中需要使用一张SQLite数据表,在Xcode中创建一张表的实现:
首先,在xcode文件导航中选中该文件,前面的SQLiteDemo是项目名称
然后在打开的界面的下方点击Add Entity按钮来添加一张数据表
Xcode中的一个Entity对应的就是一张数据表,可以对数据表进行命名,但是必须是以大写字母开头,否则XCode会发出警告我这里使用User来演示
然后点击Attribute中的+来添加字段,这里添加name和age字段进行测试
至此,创建数据表完成。
然后需要一个对象来封装我们要添加的数据,这就是之前说的NSManagedObject对象。可以用这种方式创建一个对象
insertNewObjectForEntityForName方法的第一个参数是要操作的Entity名,也就是数据表名,第二个字段是数据库上下文(NSManagedObjectContext实例)。
人后通过KVO的方式像这个对象传入我们的数据,我这里的数据是从UITextField中获得的。
然后需要把该对象保存到SQLite中
save方法的参数是一个NSError,这里传入nil,具体处理方法不再赘述,后文同样不做处理。
然后用数据库上下文进行查询,将结果保存到名为data的数组中,其类型为AnyObject
然后,可以通过KVO的方式从中取出数据
首先设置更新的数据
然后把更新完的数据实例进行保存即可,此时的数据库上下文要从该数据对象中获得
要使用CoreData切记在创建项目的时候选中CoreData选项。
在操作SQLite的时候最终要的是获得一个NSManagedObjectContext对象,这个对象在AppDelegate中可以获得,而AppDelegate实例可以在UIApplication中获得,swift获得NSManagedObjectContext对象的实现可以这样写
context = (UIApplication.sharedApplication().delegate as! AppDelegate).managedObjectContext
SQLite中的每一条数据封装在NSManagedObject中,每一条数据都是一个NSManagedObject示例
下面的示例中需要使用一张SQLite数据表,在Xcode中创建一张表的实现:
首先,在xcode文件导航中选中该文件,前面的SQLiteDemo是项目名称
然后在打开的界面的下方点击Add Entity按钮来添加一张数据表
Xcode中的一个Entity对应的就是一张数据表,可以对数据表进行命名,但是必须是以大写字母开头,否则XCode会发出警告我这里使用User来演示
然后点击Attribute中的+来添加字段,这里添加name和age字段进行测试
至此,创建数据表完成。
添加数据
要想SQLite中添加数据,首先要获得NSManagedObjectContext实例,在上文中已经有写,在以后就不再赘述,请自行获取。然后需要一个对象来封装我们要添加的数据,这就是之前说的NSManagedObject对象。可以用这种方式创建一个对象
var row: AnyObject = NSEntityDescription.insertNewObjectForEntityForName("User", inManagedObjectContext: context)
insertNewObjectForEntityForName方法的第一个参数是要操作的Entity名,也就是数据表名,第二个字段是数据库上下文(NSManagedObjectContext实例)。
人后通过KVO的方式像这个对象传入我们的数据,我这里的数据是从UITextField中获得的。
row.setValue(nameField.text, forKey: "name") row.setValue(ageField.text.toInt(), forKey: "age")
然后需要把该对象保存到SQLite中
context.save(nil)//保存数据
save方法的参数是一个NSError,这里传入nil,具体处理方法不再赘述,后文同样不做处理。
查询数据
进行数据查询,需要一个NSFetchRequest实例进行查询操作,所以先穿件一个NSFetchRequest实例,其中的参数为Entity名var query = NSFetchRequest(entityName: "User")
然后用数据库上下文进行查询,将结果保存到名为data的数组中,其类型为AnyObject
var data = context.executeFetchRequest(query, error:nil)!
然后,可以通过KVO的方式从中取出数据
var row: (AnyObject) = data[i] var name: AnyObject = row.valueForKey("name")! var age: AnyObject = row.valueForKey("age")!
更新数据
更新数据需要先获得数据实例,这里使用上文查询数据中获得的data数组中的数据。首先设置更新的数据
data[0].setValue(nameField.text, forKey: "name") data[0].setValue(ageField.text.toInt(), forKey: "age")
然后把更新完的数据实例进行保存即可,此时的数据库上下文要从该数据对象中获得
data[0].managedObjectContext?.save(nil)//更新数据
删除数据
删除数据同样需要获得数据对象,同样使用查询到的data数组中的数据,调用数据库上下文中的deleteObject方法,传入要删除的对象,然后保存数据库上下文就可以删除数据。//删除数据操作 context.deleteObject(data[0] as! NSManagedObject) //删除完后需要把结果保存到数据库 context.save(nil)
相关文章推荐
- IOS CoreData 简单使用CURD
- IOS CoreData的简单使用
- iOS开发-CoreData的简单使用
- iOS开发-CoreData的简单使用
- iOS开发:coredata的简单使用
- iOS之CoreData基本使用以及简单封装
- IOS开发 core data 简单使用和注意
- iOS学习爬坑记录12:学习Core data简单的CURD
- ios简单使用core data
- iOS 6 编程--Core Data持久化数据存储(2)-使用Core Data实现简单ShoppingCart应用程序
- IOS中core Data框架的简单介绍
- IOS成长之路-CoreData使用
- IOS成长之路-Core Data使用时用到的类--微解
- [ios开发基础之 Core Data[3]]如何使用NSFetchedResultsController 来集成TableView操作
- iOS学习笔记14(1)—Core Data简单介绍和实现
- Core Data持久化数据存储(2)-使用Core Data实现简单ShoppingCart应用程序
- 【iOS开发】 CoreText 使用教程:以创建一个简单的杂志应用为例
- 【iOS开发】 CoreText 使用教程:以创建一个简单的杂志应用为例
- iOS:Core Data 中的简单ORM
- iOS开发】 CoreText 使用教程:以创建一个简单的杂志应用为例