我最近开始了一个 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 并没有真正找到我想要的东西 - 再说一次,这是我第一次,所以也许我做错了。
Best Answer-推荐答案 strong>
1.: 获取数据库文件的有效路径
看起来您的实际主要问题是获取数据库文件的有效路径。如果数据库文件位于 Assets 中,我也找不到任何使其工作的方法。所以不要将数据库文件保存在您的 Assets 文件夹中,而是将其添加到您当前目标的 Build Phases 设置中的 Copy Bundle Resources 列表中。 如果您的文件名为 myDb.db ,那么您可以获得这样的有效路径:
let dbUrl = Bundle.main.url(forResource: "myDb", withExtension: "db")!
let dbPath = dbUrl.path
2.:访问您的数据库(无需复制)
现在可以访问您的数据库,而无需(手动?)复制它。只需使用已经提到的 SQLite.swift图书馆:
db = try! Connection(dbPath)
注意事项:
由于问题有点老了,所以在询问时可能无法像这样访问数据库文件。但是,它现在确实有效。我唯一尚未明确检查的是写入数据库。不过,至少只读访问确实很有效。
关于ios - 如何在 iOS 中使用现有的 SQLite 数据库?,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/44870206/
|