我最近开始了一个 iOS 项目,需要使用一个独立的数据库,当有更新时,该数据库将从互联网上下载。这是我的第一个 iOS 项目,所以在设计下载机制之前尝试让功能正常工作。
我选择了 SQLite 包装器 SWLite.swift
( https://github.com/stephencelis/SQLite.swift ) 并准备好查询和 TableView 。但我无法连接到数据库。我在这里尝试了几乎所有其他问题/答案,但绝对没有成功。
例如,我将 SQLite 数据库放入 Assets.xcassets
并尝试 let path = Bundle.main.path(forResource: "myDb", ofType: "db")!
,应用程序崩溃(当我返回 nil
时——大概是因为找不到路径)。同样,我尝试了其他人的建议,包括在我的 Mac 上创建一个文件夹,将文件放入其中,将 .bundle
附加到文件夹名称,然后将其放入 Assets... 再次,nil
.
有人可以建议吗?我查看了 Apple Docs 并没有真正找到我想要的东西 - 再说一次,这是我第一次,所以也许我做错了。
看起来您的实际主要问题是获取数据库文件的有效路径。如果数据库文件位于 Assets 中,我也找不到任何使其工作的方法。所以不要将数据库文件保存在您的 Assets 文件夹中,而是将其添加到您当前目标的 Build Phases 设置中的 Copy Bundle Resources 列表中。 如果您的文件名为 myDb.db
,那么您可以获得这样的有效路径:
let dbUrl = Bundle.main.url(forResource: "myDb", withExtension: "db")!
let dbPath = dbUrl.path
现在可以访问您的数据库,而无需(手动?)复制它。只需使用已经提到的 SQLite.swift图书馆:
db = try! Connection(dbPath)
注意事项: 由于问题有点老了,所以在询问时可能无法像这样访问数据库文件。但是,它现在确实有效。我唯一尚未明确检查的是写入数据库。不过,至少只读访问确实很有效。
关于ios - 如何在 iOS 中使用现有的 SQLite 数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44870206/
欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) | Powered by Discuz! X3.4 |