菜鸟教程小白 发表于 2022-12-11 20:01:02

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


                                            <p><p>我最近开始了一个 iOS 项目,需要使用一个独立的数据库,当有更新时,该数据库将从互联网上下载。这是我的第一个 iOS 项目,所以在设计下载机制之前尝试让功能正常工作。</p>

<p>我选择了 SQLite 包装器 <code>SWLite.swift</code> ( <a href="https://github.com/stephencelis/SQLite.swift" rel="noreferrer noopener nofollow">https://github.com/stephencelis/SQLite.swift</a> ) 并准备好查询和 TableView 。但我无法连接到数据库。我在这里尝试了几乎所有其他问题/答案,但绝对没有成功。 </p>

<p>例如,我将 SQLite 数据库放入 <code>Assets.xcassets</code> 并尝试 <code>let path = Bundle.main.path(forResource: "myDb", ofType: "db")! </code>,应用程序崩溃(当我返回 <code>nil</code> 时——大概是因为找不到路径)。同样,我尝试了其他人的建议,包括在我的 Mac 上创建一个文件夹,将文件放入其中,将 <code>.bundle</code> 附加到文件夹名称,然后将其放入 Assets... 再次,<code>nil </code>.</p>

<p>有人可以建议吗?我查看了 Apple Docs 并没有真正找到我想要的东西 - 再说一次,这是我第一次,所以也许我做错了。</p></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><h2>1.: 获取数据库文件的有效路径</h2>

<p>看起来您的实际主要问题是获取数据库文件的有效路径。如果数据库文件位于 Assets 中,我也找不到任何使其工作的方法。所以<strong>不要将数据库文件保存在您的 Assets 文件夹中,而是将其添加到您当前目标的 <em>Build Phases</em> 设置中的 <em>Copy Bundle Resources</em> 列表中。</strong> 如果您的文件名为 <code>myDb.db</code>,那么您可以获得这样的有效路径:</p>

<pre><code>let dbUrl = Bundle.main.url(forResource: &#34;myDb&#34;, withExtension: &#34;db&#34;)!
let dbPath = dbUrl.path
</code></pre>

<h2>2.:访问您的数据库(无需复制)</h2>

<p><strong>现在可以访问您的数据库,而无需(手动?)复制它。</strong>只需使用已经提到的 <a href="https://github.com/stephencelis/SQLite.swift" rel="noreferrer noopener nofollow">SQLite.swift</a>图书馆:</p>

<pre><code>db = try! Connection(dbPath)
</code></pre>

<p><em>注意事项:</em>
由于问题有点老了,所以在询问时可能无法像这样访问数据库文件。但是,它现在确实有效。我唯一尚未明确检查的是写入数据库。不过,至少只读访问确实很有效。</p></p>
                                   
                                                <p style="font-size: 20px;">关于ios - 如何在 iOS 中使用现有的 SQLite 数据库?,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/44870206/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/44870206/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: ios - 如何在 iOS 中使用现有的 SQLite 数据库?