Android sqlite分页上传离线订单后删除

1、判断订单表的的总数是否大于0,如果大于0开始上传订单

java 复制代码
 public int getOrderCount() {
        String query = "SELECT COUNT(*) FROM " + TABLE_NAME;
        Cursor cursor = db.rawQuery(query, null);

        int count = 0;

        if (cursor.moveToFirst()) {
            count = cursor.getInt(0);
        }

        cursor.close();

        return count;
    }

2、每一页20条数据的查询

java 复制代码
public List<DBOrder> query(String condition) {
        String sql = String.format("SELECT * FROM %s WHERE %s LIMIT %d;", TABLE_NAME, condition,20);
        List<DBOrder> infoList = new ArrayList<>();
        // 执行记录查询动作,该语句返回结果集的游标
        //参数一:SQL查询
        //参数二:selectionArgs
        //您可以在查询的 where 子句中包含 ?s,它将被 selectionArgs 中的值替换。这些值将绑定为字符串。
        Cursor cursor = db.rawQuery(sql, null);
//        Logger.json(JSON.toJSONString(cursor));
        // 循环取出游标指向的每条记录
        while (cursor.moveToNext()) {
            DBOrder dbOrder = new DBOrder();
            dbOrder.sn = cursor.getString(cursor.getColumnIndex("sn"));
            dbOrder.card_no = cursor.getString(cursor.getColumnIndex("card_no"));
            dbOrder.total_amount = cursor.getString(cursor.getColumnIndex("total_amount"));
            dbOrder.rowid = cursor.getLong(cursor.getColumnIndex("id"));
            dbOrder.update_time = cursor.getString(cursor.getColumnIndex("update_time"));
            dbOrder.is_metering = cursor.getString(cursor.getColumnIndex("is_metering"));
            dbOrder.terminal_params = cursor.getString(cursor.getColumnIndex("terminal_params"));
            dbOrder.ftoken = cursor.getString(cursor.getColumnIndex("ftoken"));
            dbOrder.uid = cursor.getString(cursor.getColumnIndex("uid"));
            dbOrder.is_off = cursor.getString(cursor.getColumnIndex("is_off"));
            dbOrder.pay_type = cursor.getString(cursor.getColumnIndex("pay_type"));
            infoList.add(dbOrder);
        }
        //查询完毕,关闭数据库游标
        cursor.close();
        return infoList;
    }

3、获取infoList后传给后台,如果code返回200,收集ids删除掉传入的数据,在循环到第一步,直到彻底上传完为止

java 复制代码
 List<Long> ids = new ArrayList<>();
                        for (DBOrder dbOrder : dbOrders){
                            ids.add(dbOrder.rowid);
                        }
java 复制代码
public void delOrder(List<Long> ids) {
        if (ids == null || ids.isEmpty()) {
            return;
        }

        StringBuilder idList = new StringBuilder();
        for (Long id : ids) {
            if (idList.length() > 0) {
                idList.append(",");
            }
            idList.append(id);
        }

        Logger.d("删除:" + ids);
        // 构建删除条件,将传入的ID列表拼接成适当的条件
        String condition = "id IN (" + idList.toString() + ")";

        // 执行删除操作
        db.delete(TABLE_NAME, condition, null);
    }

分页加载数据: 如果数据库中的数据量很大,不要一次性加载所有数据到 List<DBOrder> 中。而是分页加载,每次加载一小部分数据。这可以减轻内存负担。

相关推荐
怒放吧德德11 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆13 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
火柴就是我13 小时前
让我们实现一个更好看的内部阴影按钮
android·flutter
心之语歌15 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊16 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang16 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
Ray Liang18 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Java水解18 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
砖厂小工20 小时前
用 GLM + OpenClaw 打造你的 AI PR Review Agent — 让龙虾帮你审代码
android·github
张拭心20 小时前
春节后,有些公司明确要求 AI 经验了
android·前端·人工智能