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

ios - 如何在 iOS 中使用现有的 SQLite 数据库?

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

我最近开始了一个 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-推荐答案


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/

回复

使用道具 举报

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

本版积分规则

关注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