微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ios – 如何使用swift 3 xcode 8在核心数据中预加载数据库

我有一个包含数据的数据库,我想在应用程序中预加载它.在 swift 3之前它可以工作,我已经按照本教程: http://www.appcoda.com/core-data-preload-sqlite-database/但是如何为swift 3加载相同的数据库?在介绍NSPersistentContainer时如何加载我项目中的.sqlite文件

解决方法

实际上,在swift 3中更改了创建数据库认路径.所以现在代码看起来像:

func preloadDBData() {
    let sqlitePath = Bundle.main.path(forResource: "MyDB",ofType: "sqlite")
    let sqlitePath_shm = Bundle.main.path(forResource: "MyDB",ofType: "sqlite-shm")
    let sqlitePath_wal = Bundle.main.path(forResource: "MyDB",ofType: "sqlite-wal")

    let URL1 = URL(fileURLWithPath: sqlitePath!)
    let URL2 = URL(fileURLWithPath: sqlitePath_shm!)
    let URL3 = URL(fileURLWithPath: sqlitePath_wal!)
    let URL4 = URL(fileURLWithPath: NSPersistentContainer.defaultDirectoryURL().relativePath + "/MyDB.sqlite")
    let URL5 = URL(fileURLWithPath: NSPersistentContainer.defaultDirectoryURL().relativePath + "/MyDB.sqlite-shm")
    let URL6 = URL(fileURLWithPath: NSPersistentContainer.defaultDirectoryURL().relativePath + "/MyDB.sqlite-wal")

    if !FileManager.default.fileExists(atPath: NSPersistentContainer.defaultDirectoryURL().relativePath + "/MyDB.sqlite") {
        // copy 3 files
        do {
            try FileManager.default.copyItem(at: URL1,to: URL4)
            try FileManager.default.copyItem(at: URL2,to: URL5)
            try FileManager.default.copyItem(at: URL3,to: URL6)

            print("=======================")
            print("FILES copIED")
            print("=======================")

        } catch {
            print("=======================")
            print("ERROR IN copY OPERATION")
            print("=======================")
        }
    } else {
        print("=======================")
        print("FILES EXIST")
        print("=======================")
    }
}

现在你可以从AppDelegate的didFinishLaunchWithOptions方法调用这个方法,这将预加载我们放在应用程序中的数据库.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐