在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;
}
参考数据库处理方法,用户删除并不是真正的删除,而是在一个字段中标志这个数据删除了。用户看不见,认为其被删除而已