我试图创建一个Entry对象,并一次性添加一个关系对象,但我似乎得到了一个继续操作的错误。
我遇到的问题是当我创建初始Entry对象(1)并添加一个Exercise对象时,它工作正常。然后,当我将第二个Exercise对象作为单独的动作添加到Entry对象(1)时,将创建一个新的Entry对象(2),而不是使用我创建的第一个。当我尝试将第三个/第四个/第五个Exercise对象添加到条目对象(按日期区分)时,新练习将添加到第一个Entry对象(1)。不确定我是否正确使用NSManagedObjectContext,这最终导致了这个错误。
下面是它的架构。 Entry对象与Exercise对象具有OneToMany关系。
以下是我在各种文件中使用的代码。
DateModel.swift
class DateModel {
static let sharedInstance = DateModel()
var selectedDate: NSDate! = nil
var context = (UIApplication.sharedApplication().delegate as! AppDelegate).managedObjectContext
private init() {
// self.selectedDate = "No date selected"
}
func getEntryForSelectedDate() -> Entry {
let fetchRequest = NSFetchRequest(entityName: "Entry")
fetchRequest.predicate = NSPredicate(format: "date = %@", selectedDate)
var error: NSError?
entries = self.context!.executeFetchRequest(fetchRequest, error: &error) as! [Entry]
var entry: Entry? = nil
if entries.count > 1 {
entry = entries[0] as Entry
} else {
entry = (NSEntityDescription.insertNewObjectForEntityForName("Entry", inManagedObjectContext: self.context!) as? Entry)!
}
return entry!
}
func addExerciseToDay(exercise: String) {
var entryToUpdate = getEntryForSelectedDate()
var newExercise = NSEntityDescription.insertNewObjectForEntityForName("Exercise", inManagedObjectContext: self.context!) as! Exercise
entryToUpdate.date = selectedDate
newExercise.name = exercise
newExercise.createdAt = NSDate()
newExercise.entry = entryToUpdate
entryToUpdate.hasEntry = true
var error: NSError?
if !self.context!.save(&error) {
println("Unresolved error \(error), \(error!.userInfo)")
}
}
}
ExerciseListViewController.swift
override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
DateModel.sharedInstance.addExerciseToDay(self.exerciseList[indexPath.row])
self.navigationController?.popViewControllerAnimated(true)
}
我是否遗漏了某些内容,或者使用Swift有更好的方法来解决这个问题吗?
非常感谢任何帮助。
由于
答案 0 :(得分:1)
if entries.count > 1
仅当存在(至少)两个现有对象时,才为真。你是什么 可能想要的是
if entries.count >= 1
以便使用新关系更新单个现有对象。