я снова изо всех сил пытаюсь решить основную задачу данных, которая продолжает случайным образом терпеть неудачу на мне
Следующий код создает мою исходную базу данных, которая необходима для правильной работы приложения.
(...)
let context = await (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
(...)
for person in groupOfPeople { //singlePerson (codable Struct) <> SinglePerson (NSManagedObject)
saveSinglePerson(sPerson: person, context: context)
counter+=1
}
logComment = logComment + "..success!(\(counter))"
func saveSinglePerson(sPerson: singlePerson, context: NSManagedObjectContext) {
let newSinglePerson = SinglePerson(context: context)
newSinglePerson.id = sPerson.ID
newSinglePerson.name = sPerson.name
newSinglePerson.age = sPerson.age
(...)
context.performAndWait {
do {
try context.save()
}catch let error {
print(error)
Logging.insertError(message: "IMPORT ERROR: \(error.localizedDescription)", location: "buildDatabase20")
}
}
}
Теперь вот моя проблема: Сначала я даже не заметил, что есть проблема, потому что все работает нормально, и все объекты сохраняются так, как они должны быть, но на самом деле он есть, потому что: я случайно получаю такую ошибку:
error= Error Domain=NSCocoaErrorDomain Code=134030 "An error occurred while saving." UserInfo = {NSAffectedObjectsErrorKey=(
"<AppName.SinglePerson: 0x60000104e7b0> (entity: SinglePerson; id: 0x600003337ce0 <x-coredata:///SinglePerson/t3081F988-C5D1-4532-AD81-46F3B4B10215139>; data: {\n id = 138;\n name = testname;\n age = \"25\";\n })"
и я получаю эту ошибку несколько раз (20x-150x), только с этим одним единственным идентификатором, в этом примере 138, но каждый раз это другой идентификатор... Я исследую эту ситуацию уже несколько дней, и я просто не могу обдумать это. что я узнал на данный момент: метод должен вставить 150 строк, и если эта ошибка возникает, это не просто счет 149, это как 87, или 127, или что-то еще похоже, что объект застревает в контексте, и каждое выполнение после первой ошибки терпит неудачу и выдает (ту же) ошибку.
я пытался получить эти новые записанные данные сразу после того, как вставил их, и всегда получаю одно и то же (неправильное) количество 150.. я знаю, что этот счет не является законным, потому что, если я посмотрю на файл sqllite, я увижу только 87, или 127, или любое другое количество строк.
я делаю эту выборку снова с тем же контекстом, поэтому я думаю, что проблема находится в моем контексте NSManaged.
почему это происходит со мной? и почему это происходит иногда, а не постоянно? Как мне это решить?
хорошо, но я не понимаю, где и почему, я уже изолировал эту часть, насколько мог, и это продолжает происходить, большую часть времени на 7-м пробеге спина к спине..черт возьми, как мне это исправить??
Речь идет не об изоляции, а об организации, вы, кажется, смешиваете асинхронное ожидание со старыми методами, придерживайтесь одного (асинхронное ожидание), смотрите видео WWDC по асинхронному ожиданию и основным данным.
хороший момент, и это то, что я сделал, и я заметил, что, возможно, многие вещи не оптимальны в случае моего приложения, но мне удалось временно решить эту проблему, и я опубликую решение, но я действительно должен переделайте мои методы coreData с нуля (снова) :)
я нашел решение для устранения этой проблемы, хотя теперь я знаю, что мне придется переработать все взаимодействия Core Data с нуля, чтобы сделать его действительно стабильным и надежным. это мой первый быстрый проект, так что по пути все стало довольно грязно :)
fix: тот факт, что теперь я сохраняю все созданные объекты сразу, а не сохраняю каждый элемент отдельно, сработало и решило проблему для меня в этот самый момент :)
может быть, это полезно для кого-то еще;)
(...)
let context = await (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
(...)
var personArray = [SinglePerson]()
for person in groupOfPeople {
let newSinglePerson = SinglePerson(context: context)
newSinglePerson.id = sPerson.ID
newSinglePerson.name = sPerson.name
newSinglePerson.age = sPerson.age
(...)
personArray.append(newSinglePerson)
}
context.performAndWait {
do {
try context.save()
} catch let error {
print(error.localizedDescription)
}
}
Это проблема синхронизации, у меня только что это произошло с клиентом, и мы переписали код приложения где-то, где вы перескакиваете потоки, которые портят синхронизацию.