У меня есть база данных областей, которая состоит из года -> месяц -> день -> элементы
стрелки переходят из родительской категории в дочернюю категорию.
Я могу сохранить вычисление один раз, но если я сделаю это снова, он выдаст ошибку, что месяц первичного ключа 0 уже существует. Я знаю, что это такое, поэтому я хочу, чтобы Realm обновил его. Как я хочу сохранить каждый месяц только один раз и каждый год только один раз.
//MARK: - Realm Database Saving option
@objc func saveCalculation(){
let date = Date()
let dateElements = getDate()
let yearObject = Year()
yearObject.number = dateElements.year
let monthObject = Month()
monthObject.number = dateElements.month
monthObject.monthName = dateElements.monthName
let dayObject = Day()
dayObject.id = realm.objects(Day.self).count
dayObject.date = date
dayObject.number = dateElements.day
dayObject.dayName = dateElements.dayNameInWeek
dayObject.hoursPerDay = hoursPerDay
dayObject.ratePerHour = ratePerHour
dayObject.minutesOfNormalPay = minutesOfNormalPay
dayObject.earnedPerDay = earnedPerDay
dayObject.howManyRows = rowViews.count
do {
try realm.write {
realm.add(yearObject, update: true)
yearObject.months.append(monthObject)
realm.add(monthObject, update: true)
monthObject.days.append(dayObject)
realm.add(dayObject, update: false)
for (index, row) in rowViews.enumerated() {
let item = Item()
item.id = index
item.date = date
item.amount = Double(row.amountTextField.text!) ?? 0.0
item.price = Double(row.priceTextField.text!) ?? 0.0
print("Item amount: \(item.amount) and price: \(item.price)")
dayObject.items.append(item)
realm.add(item)
}
}
} catch {
print(error.localizedDescription)
}
}
func getDate() -> (day: Int, dayNameInWeek: String, month: Int, monthName: String, year: Int) {
let date = Date()
let dayNameInWeek = date.getDayName()
let monthName = date.getMonthName()
let calendar = Calendar.current
let components = calendar.dateComponents([.year, .month, .day], from: date)
let year = components.year!
let month = components.month!
let day = components.day!
print(year)
print(month)
print(monthName)
print(day)
print(dayNameInWeek)
return (day,dayNameInWeek, month, monthName, year)
}
каждый класс базы данных соответственно:
import Foundation
import RealmSwift
class Year: Object {
//@objc dynamic var year = Date()
@objc dynamic var id: Int = 0
@objc dynamic var number: Int = 2008
let months = List<Month>() //forward relationship to Months
override class func primaryKey() -> String {
return "id"
}
}
Месяц:
import Foundation
import RealmSwift
class Month: Object {
@objc dynamic var id: Int = 0
@objc dynamic var number: Int = 0
@objc dynamic var monthName: String = ""
@objc dynamic var monthYear: Int = 0
let days = List<Day>() //forward relationship to Days
let parentYear = LinkingObjects(fromType: Year.self, property: "months") //back relationship to year
override class func primaryKey() -> String {
return "id"
}
}
день:
import Foundation
import RealmSwift
class Day: Object {
@objc dynamic var id: Int = 0
@objc dynamic var date: Date = Date()
@objc dynamic var number: Int = 0
@objc dynamic var dayName: String = ""
@objc dynamic var hoursPerDay: Double = 0.0
@objc dynamic var ratePerHour: Double = 0.0
@objc dynamic var minutesOfNormalPay: Double = 0.0
@objc dynamic var earnedPerDay: Double = 0.0
@objc dynamic var howManyRows: Int = 0
let items = List<Item>() //forward relationship to Items
let parentMonth = LinkingObjects(fromType: Month.self, property: "days") //back relationship to months
override class func primaryKey() -> String {
return "id"
}
}
Пункт:
import Foundation
import RealmSwift
class Item: Object {
@objc dynamic var id: Int = 0
@objc dynamic var date: Date = Date()
@objc dynamic var amount: Double = 0.0
@objc dynamic var price: Double = 0.0
let parentDay = LinkingObjects(fromType: Day.self, property: "items") //back relationship to days
}