티스토리 뷰
728x90
반응형
Core Data CRUD
NSManagedObjectContext
여러가지 transaction 메소드를 살펴보자
- manager class
AppDelegate.swift 에서 persistentContainer 를 계속 가져왔지만 매니저 클래스를 만들어서 사용하자
import Foundation
import CoreData
class PersistenceManager {
static var shared: PersistenceManager = PersistenceManager()
lazy var persistentContainer: NSPersistentContainer = {
let container = NSPersistentContainer(name: "Model")
container.loadPersistentStores(completionHandler: { (storeDescription, error) in
if let error = error as NSError? {
fatalError("Unresolved error \(error), \(error.userInfo)")
}
})
return container
}()
var context: NSManagedObjectContext {
return self.persistentContainer.viewContext
}
}
여기에 기능에 맞는 코드를 추가할 것이다.
그전에 @discardableResult
에 대해서 사용할 것이기 때문에 공부해보자.
- 문구 그대로 결과를 버릴 수 있는 의미
함수의 return 값을 discadable 시킬 수 있다. 즉, return 값을 사용하지 않아도 warning 메시지가 나오지 않는다.
insertStory(), deleteAll(), delete() 에서만 선언해준다.
- fetch
//fetch
func fetch<T :NSManagedObject>(reqeust: NSFetchRequest<T>) -> [T] {
do {
let fetchResult = try self.context.fetch(reqeust)
return fetchResult
} catch {
print(error.localizedDescription)
return []
}
}
// 사용
// let request: NSFetchRequest<StoryModel> = StoryModel.fetchRequest()
// let fetchResult = PersistenceManager.shared.fetch(reqeust: request)
- insert
//insert data
@discardableResult
func insertStory(story: Story) -> Bool {
let entity = NSEntityDescription.entity(forEntityName: "StoryModel", in: self.context)
if let entity = entity {
let managedObject = NSManagedObject(entity: entity, insertInto: self.context)
managedObject.setValue(story.title, forKey: "title")
managedObject.setValue(story.detail, forKey: "detail")
managedObject.setValue(story.date, forKey: "date")
do {
try self.context.save()
return true
} catch {
print(error.localizedDescription)
return false
}
} else {
return false
}
}
// 사용
// let storyOne = Story(title: "story1", detail: "detail1", date: "date1")
// PersistenceManager.shared.insertStory(story: storyOne)
- update
// update
@discardableResult
func updateStory<T :NSManagedObject>(reqeust: NSFetchRequest<T>, index: Int, story: Story) -> Bool {
do{
let fetchResult = try self.context.fetch(reqeust)
let objectUpdate = fetchResult[index]
objectUpdate.setValue(story.title, forKey: "title")
objectUpdate.setValue(story.detail, forKey: "detail")
objectUpdate.setValue(story.date, forKey: "date")
do {
try self.context.save()
return true
} catch {
print(error.localizedDescription)
return false
}
} catch {
print(error.localizedDescription)
return false
}
// 사용
// update
// let request: NSFetchRequest<StoryModel> = StoryModel.fetchRequest()
// PersistenceManager.shared.updateStory(reqeust: request, index: index, story: story)
}
- delete
// delete
@discardableResult
func delete(object: NSManagedObject) -> Bool {
self.context.delete(object)
do {
try context.save()
return true
} catch {
return false
}
}
// 사용
// let request: NSFetchRequest<StoryModel> = StoryModel.fetchRequest()
// let fetchResult = PersistenceManager.shared.fetch(reqeust: request)
// PersistenceManager.shared.delete(object: fetchResult.last!)
- delete all
// delete all
@discardableResult
func deleteAll<T: NSManagedObject>(request: NSFetchRequest<T>) -> Bool {
let request: NSFetchRequest<NSFetchRequestResult> = T.fetchRequest()
let delete = NSBatchDeleteRequest(fetchRequest: request)
do {
try self.context.execute(delete)
return true
} catch {
return false
}
}
// 사용
// let request: NSFetchRequest<StoryModel> = StoryModel.fetchRequest()
// PersistenceManager.shared.deleteAll(request: request)
// let arr = PersistenceManager.shared.fetch(request: request)
// if arr.isEmpty {
// print("clean") // Print "clean"
// }
- count
// count
func count<T: NSManagedObject>(request: NSFetchRequest<T>) -> Int? {
do {
let count = try self.context.count(for: request)
return count
} catch {
return nil
}
}
// 사용
// let request: NSFetchRequest<StoryModel> = StoryModel.fetchRequest()
// print(PersistenceManager.shared.count(request: request))
728x90
반응형
'iOS' 카테고리의 다른 글
iOS) User Defaults vs Core Data (0) | 2021.07.22 |
---|---|
iOS) Date 로 날짜다루기 (0) | 2021.07.22 |
iOS) 스와이프해서 pop 하기 (0) | 2021.07.22 |
iOS) 스크롤에 따라서 동적으로 뷰의 높이조절 (4) | 2021.07.22 |
iOS) UITableView cell selectedBackground (0) | 2021.07.22 |
댓글
TAG
- Objective-C
- OpenSourceLibrary
- IOS
- Protocol
- Widget
- APNS
- urlsession
- Swift
- WWDC
- WidgetKit
- YPImagePicker
- SwiftUI
- 서버통신
- containerBackground
- Firebase
- async/await
- 2022 KAKAO TECH INTERNSHIP
- WWDC22
- RxCocoa
- Notification
- github
- CloneCoding
- MOYA
- projectsetting
- rxswift
- MVVM
- configurable widget
- UserDefaults
- watchOS
- Algorithm
최근에 올라온 글
최근에 달린 댓글
글 보관함
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
링크
- Total
- Today
- Yesterday