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> 中。而是分页加载,每次加载一小部分数据。这可以减轻内存负担。

相关推荐
1988我想和这个世界谈谈36 分钟前
java实现预览服务器文件,不进行下载,并增加水印效果
java·文件预览·水印
PigeonGuan40 分钟前
[Linux] 服务器CPU信息
java·linux·服务器
ppo_wu1 小时前
解决:com.mongodb.MongoSocketOpenException: Exception opening socket
java·数据库·spring boot·mongodb
啊烨疯狂学java1 小时前
1231java面经md
java·算法·面试·排序算法
NHuan^_^1 小时前
RabbitMQ基础篇之Java客户端快速入门
java·rabbitmq·java-rabbitmq
vistaup1 小时前
Android ADB shell 填充SD卡(反复擦写防恢复
android·adb
_半夏曲2 小时前
工厂+策略模式之最佳实践(疾病报卡维护模块API设计)
java·开发语言·设计模式
ChoSeitaku2 小时前
No.2十六届蓝桥杯备战|练习题4道|数据类型|字符型|整型|浮点型|布尔型|signed|unsigned(C++)
java·c++·算法
1.01^10002 小时前
[2474].第04节:Activiti官方画流程图方式
java·流程图·activiti
天花板之恋2 小时前
Lottie动画源码解析
android·动画·lottie