gpt4 book ai didi

Android SQLite 需要很长时间才能完成

转载 作者:行者123 更新时间:2023-11-30 04:48:57 24 4
gpt4 key购买 nike

我正在构建一个 Android 应用程序,但我的 SQL 操作需要很长时间才能完成,我对此一无所知

我已经对应用程序进行了概要分析,将其缩小到将光标移动到结果集的第一行以进行简单选择查询的行为(仅返回我正在测试它以消除结果大小的一行)设置为问题。

移动到结果集的开头是否有更好的选择?

编辑:

一些代码:

public Cursor sqlQuery(String Sql)
{
Cursor c = database.rawQuery(Sql, null);
//start at the first spot
c.moveToFirst();
return c;
}

调用代码

    Cursor Slots = evedb.sqlQuery("SELECT attrib.value, "
+"attribtypes.attributename "
+"FROM dgmTypeAttribs AS attrib "
+"INNER JOIN invTypes AS type "
+"ON attrib.typeID = type._ID "
+"INNER JOIN dgmAttribs AS attribtypes "
+"ON attrib.attributeID = attribtypes._ID "
+"AND attribtypes.attributename = 'hiSlots' "
+"AND type.typeName = '" + shipname + "'");

这运行了 3 次,对于所有其余代码,我有大约 2 秒的时间,或者有超过一分钟的时间。

我也只运行了 rawQuery 语句,没有移动到 first,它大约需要 18 秒,所以我首先查看代码中最糟糕的部分。

最佳答案

您可能拥有大型数据集。你可以做什么:

  1. 确保您有适当的索引(您的所有 FK 字段都已编入索引?您是否在每个表的 _ID 字段上设置了 PK?)在 ON 或 WHERE 语法中使用的每个字段都应编入索引(一般来说)。

  2. 您应该稍微更改一下您的查询:

    +"ON attrib.attributeID = attribtypes._ID "
    +"WHERE attribtypes.attributename = 'hiSlots' "
    +"AND type.typeName = '" + shipname + "'");
  3. 考虑使用 PreparedStatement

  4. 检查此查询使用的数据量 - 删除 where 条件并只输入 count(*)

  5. 考虑将一个大查询拆分为几个较小的查询。还有 EXPLAIN 命令,可用于检查 SQLite 使用的检索数据的方式。看here获取更多信息。

移动到第一行是查询开始收集数据的时间点,所以这只是数据库性能问题。

关于Android SQLite 需要很长时间才能完成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4077348/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com