• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - 如何快速创建 Core Data 数据库 4

[复制链接]
菜鸟教程小白 发表于 2022-12-13 03:38:18 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

请分享一些用于数据库保存详细信息的示例代码片段,并在 swift 4 中获取保存的详细信息



Best Answer-推荐答案


这是我的答案

第 1 步:创建 Coredata 堆栈类,见下文

var coreDataStack: CoreDataStack = CoreDataStack()//在 appDelegate 上添加这一行

    class Stack
    {
    lazy var managedObjectModel: NSManagedObjectModel = {
    let modelUrl = Bundle.main.url(forResource: "Model", withExtension: "momd")!
    return NSManagedObjectModel(contentsOf: modelUrl)!
}()


lazy var peristentStoreCoordinator: NSPersistentStoreCoordinator = {
    let coordinator: NSPersistentStoreCoordinator = NSPersistentStoreCoordinator(managedObjectModel: self.managedObjectModel)
    let applicationDocumentsDirectory: URL = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).last!
    let persistentStoreUrl: URL = applicationDocumentsDirectory.appendingPathComponent("Model.sqlite")

    do {
        try coordinator.addPersistentStore(ofType: NSSQLiteStoreType, configurationName: nil, at: persistentStoreUrl, options: nil)
    }
    catch {
        fatalError("ersistent store error! \(error)")
    }

    return coordinator
}()


lazy var managedObjectContext: NSManagedObjectContext = {
    let managedObjectContext: NSManagedObjectContext = NSManagedObjectContext(concurrencyType: .mainQueueConcurrencyType)
    managedObjectContext.persistentStoreCoordinator = self.peristentStoreCoordinator

    return managedObjectContext
}()


func saveContext() {
    if self.managedObjectContext.hasChanges {
        do {
            try self.managedObjectContext.save()
            }
            catch {
                fatalError("There was an error saving the managed object context \(error)")
            }
        }
    }
}

第 2 步:创建实体 第 3 步:创建 ManagedObjectModelSubclass -- 编辑器 -> ManagedObjectModelSubclass 第四步:导入类的核心数据并添加以下代码

    var person = [Person]() //[Person] here denote subclassclass name
    var  appDelegate = UIApplication.shared.delegate as! AppDelegate

    let personEntity: NSEntityDescription? = NSEntityDescription.entity(forEntityName: "EntityName", in: self.appDelegate.coreDataStack.managedObjectContext)

    if personEntity != nil {

        let person1: Person = Person(entity: personEntity!, insertInto: self.appDelegate.coreDataStack.managedObjectContext)
        person1.name = "name"
        person1.country = "US"
        person1.age = "26"
        person1.place = "NewYork"
     }

第 5 步:使用以下代码获取数据

  var persons: [Person] = [] // subclass name

  var appDelegate: AppDelegate = UIApplication.shared.delegate as! AppDelegate

var listdata = [ModelClass]() // create a modelclass object

  func fetchDemoData() {
    let fetchRequest: NSFetchRequest = NSFetchRequest<NSFetchRequestResult>(entityName: "EntityName")
    do {
        if let results = try self.appDelegate.coreDataStack.managedObjectContext.fetch(fetchRequest) as? [NSManagedObject] {
            let personList: [Person]? = results as? [Person]
            if personList != nil {
                self.persons = personList!


                for eachData in persons {

                    let name = eachData.name as String!
                    let username = eachData.age as String!
                    let email = eachData.country as String!
                    let address = eachData.place as! [String : Any]

                    self.listdata.append(ModelClass(name: name!, username: username!,email : email!,address : address))
                }

                 //self.tableview.reloadData()

            }


        }
    }
    catch {
        fatalError("There was an error fetching the items")
    }
}

关于ios - 如何快速创建 Core Data 数据库 4,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47671215/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap