菜鸟教程小白 发表于 2022-12-12 09:46:43

ios - 使用 FMDB 将数据插入 SQLite 时 dispatch_async 上的 EXC_BAD_ACCESS


                                            <p><p>所以,我已经阅读了我在互联网上找到的所有帖子,但我似乎仍然无法完成这项工作。 </p>

<p>我正在尝试将大量数据插入 sqlite 数据库。这是20000行数据,所以我必须在后台线程中进行。 </p>

<p>我有一个 NSObject .h 和 .m 文件来处理数据库操作。我从我的主视图中调用它们。 </p>

<p>这是我的代码:</p>

<pre><code>SQLiteDBHandler.m :

database = ];
    ;
    dispatch_queue_t q = dispatch_queue_create(&#34;FMDBQueue&#34;, NULL);
    dispatch_async(q, ^{
      for(Customer *c in arrayOfObjects) {
            ;
      }
      ;
    });
</code></pre>

<p>为了在主视图中调用方法,我这样调用它:</p>

<pre><code>SQLiteDBHandler *dbHandler = [init];

;
</code></pre>

<p>我尝试使用 FMDatabaseQueue 更改 FMDatabase,但没有成功。因此,任何帮助都将受到高度赞赏,因为我对此非常绝望。</p>

<p>谢谢。干杯!</p></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><p>如果您调用 <code>InsertDataIntoTable</code> 两次,或尝试访问数据库的任何其他方法,您可能会遇到数据库连接在您有时间执行查询之前关闭的情况。
考虑这种情况:</p>

<ol>
<li>线程 1 打开数据库连接</li>
<li>线程 2 打开数据库连接</li>
<li>线程 1 向队列中添加一个 block </li>
<li>线程 2 向队列中添加一个 block </li>
<li>线程 1 完成运行并关闭数据库连接</li>
<li>线程 2 尝试运行他的 block ,但数据库连接已经关闭。</li>
</ol>

<p>尝试在 block 内调用<code>[数据库打开]</code>。</p></p>
                                   
                                                <p style="font-size: 20px;">关于ios - 使用 FMDB 将数据插入 SQLite 时 dispatch_async 上的 EXC_BAD_ACCESS,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/15494482/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/15494482/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: ios - 使用 FMDB 将数据插入 SQLite 时 dispatch_async 上的 EXC_BAD_ACCESS