sqlite优化之多表查询

本文讲述了在优化SQLite数据库查询性能时遇到的问题,即因频繁从数据库中单独加载数据导致的性能瓶颈。通过分析,发现可以通过多表查询来减少数据库操作次数,提高效率。文章介绍了left join、right join和inner join三种SQL联接方式,并提供了示例来说明它们的使用和效果。
摘要由CSDN通过智能技术生成

今天在优化公司项目中,发现一个列表在离线加载时速度非常慢,加载1000条数据,竟然需要13s!!!

跟了一下db层代码

@Override
    public ArrayList<Task> loadMineTask(String userId, boolean noblongs) {
        .....//省略
        Cursor cursor = db.rawQuery(sql, null);
        while (cursor.moveToNext()) {
            Task task = getFromCursor(cursor, false, false);

            tasks.add(task);
        }
        cursor.close();
        .....//省略
        return tasks;
    }

发现在执行rawQuery都是毫秒级,99%的时间集中在了getFromCursor(…)这个方法中了,继续跟踪:

    private Task getFromCursor(Cursor cursor, boolean isLoadAllInfo,
            boolean isLoadStages) {
        .....//省略
        String parentId = cursor.getString(cursor.getColumnIndex(FIELD_PARENT));
        if (!TextUtils.isEmpty(parentId)) {
            Task parentTask = loadTask(parentId)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值