iOS在CoreData中简单封装了SQLite,让开发者不需要写sql语句就可以使用SQLite进行CURD操作。
要使用CoreData切记在创建项目的时候选中CoreData选项。
在操作SQLite的时候最终要的是获得一个NSManagedObjectContext对象,这个对象在AppDelegate中可以获得,而AppDelegate实例可以在UIApplication中获得,swift获得NSManagedObjectContext对象的实现可以这样写
context = (UIApplication.sharedApplication().delegate as! AppDelegate).managedObjectContext
SQLite中的每一条数据封装在NSManagedObject中,每一条数据都是一个NSManagedObject示例
下面的示例中需要使用一张SQLite数据表,在Xcode中创建一张表的实现:
要想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)