首页 > recyclerview如何在onswipe删除数据后如何恢复数据。

recyclerview如何在onswipe删除数据后如何恢复数据。

onswipe中删除数据后如何恢复数据
1.

                final int position = viewHolder.getAdapterPosition();
                final thingsModel thing = adapter.getItem(position);
                //totalThing.removeThing(new thingsModel[]{thing});
                //storeThingDAO.deleteThing(sqLiteDatabase,thing.getKey());
                mList.remove(position);
                adapter.notifyItemRemoved(position);
                Snackbar.make(coordinatorLayout,R.string.back,Snackbar.LENGTH_SHORT)
                        .setAction("取消", new View.OnClickListener() {
                            @Override
                            public void onClick(View v) {
                                mList.add(position,thing);
                                adapter.notifyItemInserted(position);
                                new Thread(new Runnable() {
                                    @Override
                                    public void run() {
                                        storeThingDAO.insertThing(sqLiteDatabase,thing);
                                    }
                                }).start();
                            }
                        }).show();
                if (!mList.contains(thing)){
                    new Thread(new Runnable() {
                        @Override
                        public void run() {
                            storeThingDAO.deleteThing(sqLiteDatabase,thing.getKey());
                        }
                    }).start();
                }

我是在删除后,如果取消删除的操作,就将这个重新加回数据库中,我认为这个方法并不好,请问合理的解决方法是什么?
在生命周期中onstop中更新数据库的话,是将原表中的数据全部删除再将mlist的数据添加进去吗?


就这个需求来说不需要对数据频繁的读写,你的mList初始化数据是从数据表一次性读取的吧,可以建一个tempList暂存被删除的条目数据,对tempList进行删除的条目数据的管理(有删除操作时添加数据,action取消时移除前面删除时添加的对应的数据),在确定不再需要对列表进行编辑时(比如Activity退出时)再把tempList对应数据库进行数据持久化操作,tempList不为空时即遍历tempList,对应的数据库表数据条目进行删除,这时使用数据库事务操作会很快,tempList为空时不进行任何操作,整个过程,其实就最多只是进行了两次数据库操作(mList的查询读取和tempList的元素映射表项删除),节省了性能开支,至于“取消”的Action,要方便你从tempList查找对应的条目数据,tempList用Map创建会更合适一些(如Map<position, thingsModel>)。数据库表可以对单个条目进行删除修改操作,不需要删表再重建,那样代价太大,删除数据一般情况下毕竟是小范围的。


UI上的删除不做物理删除,恢复的时候,直接插入原来的位置即可。

用一个列表存着刚才做的那些操作


// 存在list 中
List<Action> actions = new ArrayList<>();

// 每做一步操作放一个,这样就可以一步一步的回退了。
// 删除不要做物理操作


// 操作的数据结构如下
class Action{

    public final static int REMOVE = 0x2;
    public final static int INSERT = 0x2;
    public final static int UPDATE = 0x2;
    private int actionMod;
    private int id;
    private String table;
}

参考数据库处理方法,用户删除并不是真正的删除,而是在一个字段中标志这个数据删除了。用户看不见,认为其被删除而已

【热门文章】
【热门文章】