Realm数据库使用教程(五):删除数据
2017-12-20 14:12
381 查看
Realm数据库使用教程(四):更新数据
同步删除(一):先查找到数据:deleteFirstFromRealm()
同步删除(一):先查找到数据:deleteLastFromRealm()
同步删除(一):先查找到数据:deleteAllFromRealm()
同步删除(二):后查找到数据:deleteFromRealm(int index)
同步删除(二):后查找到数据:deleteFirstFromRealm()
同步删除(二):后查找到数据:deleteLastFromRealm()
同步删除(二):后查找到数据:deleteAllFromRealm()
同步删除:deleteAll()
同步删除:delete(xxx.class)
异步删除:后查找到数据:deleteFromRealm(int index)
异步删除:后查找到数据:deleteFirstFromRealm()
异步删除:后查找到数据:deleteLastFromRealm()
异步删除:后查找到数据:deleteAllFromRealm()
异步删除:deleteAll()
异步删除(推荐使用):delete(xxx.class)
推荐使用:异步查询,同步删除
推荐使用:异步查询,异步删除
/**
* 异步操作的监听
*/
private OrderedRealmCollectionChangeListener
Realm数据库使用教程(六):数据迁移
Demo地址:https://gitee.com/huangxiaoguo/Realm
avticity全部代码如下:
Realm数据库使用教程(六):数据迁移
Demo地址:https://gitee.com/huangxiaoguo/Realm
删除数据
同步删除(一):先查找到数据:deleteFromRealm(int index)删除指定数据 final RealmResults<Student> students = mRealm.where(Student.class).findAll(); mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { students.deleteFromRealm(0); } });
同步删除(一):先查找到数据:deleteFirstFromRealm()
删除第一条数据 final RealmResults<Student> students1 = mRealm.where(Student.class).findAll(); mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { students1.deleteFirstFromRealm(); } });
同步删除(一):先查找到数据:deleteLastFromRealm()
删除最后一条数据 final RealmResults<Student> students2 = mRealm.where(Student.class).findAll(); mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { students2.deleteLastFromRealm(); } });
同步删除(一):先查找到数据:deleteAllFromRealm()
删除全部数据 final RealmResults<Student> students3 = mRealm.where(Student.class).findAll(); mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { students3.deleteAllFromRealm(); } });
同步删除(二):后查找到数据:deleteFromRealm(int index)
mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteFromRealm(0); } });
同步删除(二):后查找到数据:deleteFirstFromRealm()
mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteFirstFromRealm(); } });
同步删除(二):后查找到数据:deleteLastFromRealm()
mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteLastFromRealm(); } });
同步删除(二):后查找到数据:deleteAllFromRealm()
mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteAllFromRealm(); } });
同步删除:deleteAll()
//所有的数据库都会清除 mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.deleteAll(); } });
同步删除:delete(xxx.class)
//只会删除指定的数据库 mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.delete(Student.class); } });
异步删除:后查找到数据:deleteFromRealm(int index)
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteFromRealm(0); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("删除成功"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("删除失败"); } });
异步操作都需要取消任务 if (realmAsyncTask != null && !realmAsyncTask.isCancelled()) { realmAsyncTask.cancel(); }
异步删除:后查找到数据:deleteFirstFromRealm()
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteFirstFromRealm(); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("删除成功"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("删除失败"); } });
异步删除:后查找到数据:deleteLastFromRealm()
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteLastFromRealm(); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("删除成功"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("删除失败"); } });
异步删除:后查找到数据:deleteAllFromRealm()
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteAllFromRealm(); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("删除成功"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("删除失败"); } });
异步删除:deleteAll()
//删除所有数据库 realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.deleteAll(); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("删除成功"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("删除失败"); } });
异步删除(推荐使用):delete(xxx.class)
//删除指定的数据库 realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.delete(Student.class); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("删除成功"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("删除失败"); } });
推荐使用:异步查询,同步删除
students8 = mRealm.where(Student.class).findAllAsync(); students8.addChangeListener(callback);
/** * 异步操作的监听 */ private OrderedRealmCollectionChangeListener<RealmResults<Student>> callback = new OrderedRealmCollectionChangeListener<RealmResults<Student>>() { @Override public void onChange(RealmResults<Student> collection, OrderedCollectionChangeSet changeSet) { if (changeSet == null) { //第一次异步返回一个空的变更集。 mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.delete(Student.class); } }); } else { //每次RealmResults被更新时都会被调用 } } };
if (students8 != null) { students8.removeChangeListener(callback); students8.removeAllChangeListeners(); }
推荐使用:异步查询,异步删除
students9 = mRealm.where(Student.class).findAllAsync(); students9.addChangeListener(callback1);
/**
* 异步操作的监听
*/
private OrderedRealmCollectionChangeListener
if (students9 != null) { students9.removeChangeListener(callback); students9.removeAllChangeListeners(); }
Realm数据库使用教程(六):数据迁移
Demo地址:https://gitee.com/huangxiaoguo/Realm
avticity全部代码如下:
package tsou.com.simple.realmtest;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.List;
import io.realm.OrderedCollectionChangeSet;
import io.realm.OrderedRealmCollectionChangeListener;
import io.realm.Realm;
import io.realm.RealmAsyncTask;
import io.realm.RealmResults;
import tsou.com.simple.realmtest.adapter.MyAdapter;
import tsou.com.simple.realmtest.bean.Student;
import tsou.com.simple.realmtest.utils.UIUtils;
public class DeleteActivity extends AppCompatActivity implements AdapterView.OnItemClickListener {
private ListView mListview;
private List<String> titles = new ArrayList<>();
private Realm mRealm;
private RealmAsyncTask realmAsyncTask;
private RealmResults<Student> students8;
private RealmResults<Student> students9;
@Override
protected void onDestroy() {
super.onDestroy();
if (students8 != null) { students8.removeChangeListener(callback); students8.removeAllChangeListeners(); }
if (students9 != null) { students9.removeChangeListener(callback); students9.removeAllChangeListeners(); }
if (realmAsyncTask != null && !realmAsyncTask.isCancelled()) {
realmAsyncTask.cancel();
}
if (mRealm != null && !mRealm.isClosed()) {
mRealm.close();
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_add);
mRealm = UIUtils.getRealmInstance();
initData();
initView();
initListener();
}
private void initData() {
titles.add("同步删除(一):先查找到数据:deleteFromRealm(int index)");
titles.add("同步删除(一):先查找到数据:deleteFirstFromRealm()");
titles.add("同步删除(一):先查找到数据:deleteLastFromRealm()");
titles.add("同步删除(一):先查找到数据:deleteAllFromRealm()");
titles.add("同步删除(二):后查找到数据:deleteFromRealm(int index)");
titles.add("同步删除(二):后查找到数据:deleteFirstFromRealm()");
titles.add("同步删除(二):后查找到数据:deleteLastFromRealm()");
titles.add("同步删除(二):后查找到数据:deleteAllFromRealm()");
titles.add("同步删除:deleteAll()");
titles.add("同步删除:delete(xxx.class)");
titles.add("异步删除:后查找到数据:deleteFromRealm(int index)");
titles.add("异步删除:后查找到数据:deleteFirstFromRealm()");
titles.add("异步删除:后查找到数据:deleteLastFromRealm()");
titles.add("异步删除:后查找到数据:deleteAllFromRealm()");
titles.add("异步删除:deleteAll()");
titles.add("异步删除(推荐使用):delete(xxx.class)");
titles.add("推荐使用:异步查询,同步删除");
titles.add("推荐使用:异步查询,异步删除");
}
private void initView() {
mListview = (ListView) findViewById(R.id.listview);
mListview.setAdapter(new MyAdapter(this, titles));
}
private void initListener() {
mListview.setOnItemClickListener(this);
}
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int position, long l) {
switch (position) {
default:
break;
case 0://同步删除(一):先查找到数据:deleteFromRealm(int index)
final RealmResults<Student> students = mRealm.where(Student.class).findAll();
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
students.deleteFromRealm(0);
}
});
break;
case 1://同步删除(一):先查找到数据:deleteFirstFromRealm()
final RealmResults<Student> students1 = mRealm.where(Student.class).findAll();
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
students1.deleteFirstFromRealm();
}
});
break;
case 2://同步删除(一):先查找到数据:deleteLastFromRealm()
final RealmResults<Student> students2 = mRealm.where(Student.class).findAll();
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
students2.deleteLastFromRealm();
}
});
break;
case 3://同步删除(一):先查找到数据:deleteAllFromRealm()
final RealmResults<Student> students3 = mRealm.where(Student.class).findAll();
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
students3.deleteAllFromRealm();
}
});
break;
case 4://同步删除(二):后查找到数据:deleteFromRealm(int index)
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
RealmResults<Student> students = realm.where(Student.class).findAll();
students.deleteFromRealm(0);
}
});
break;
case 5://同步删除(二):后查找到数据:deleteFirstFromRealm()
mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteFirstFromRealm(); } });
break;
case 6://同步删除(二):后查找到数据:deleteLastFromRealm()
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
RealmResults<Student> students = realm.where(Student.class).findAll();
students.deleteLastFromRealm();
}
});
break;
case 7://同步删除(二):后查找到数据:deleteAllFromRealm()
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
RealmResults<Student> students = realm.where(Student.class).findAll();
students.deleteAllFromRealm();
}
});
break;
case 8://同步删除:deleteAll()
//所有的数据库都会清除 mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.deleteAll(); } });
break;
case 9://同步删除:delete(xxx.class)
//只会删除指定的数据库
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
realm.delete(Student.class);
}
});
break;
case 10://异步删除:后查找到数据:deleteFromRealm(int index)
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { RealmResults<Student> students = realm.where(Student.class).findAll(); students.deleteFromRealm(0); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("删除成功"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("删除失败"); } });
break;
case 11://异步删除:后查找到数据:deleteFirstFromRealm()
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
RealmResults<Student> students = realm.where(Student.class).findAll();
students.deleteFirstFromRealm();
}
}, new Realm.Transaction.OnSuccess() {
@Override
public void onSuccess() {
UIUtils.showToast("删除成功");
}
}, new Realm.Transaction.OnError() {
@Override
public void onError(Throwable error) {
UIUtils.showToast("删除失败");
}
});
break;
case 12://异步删除:后查找到数据:deleteLastFromRealm()
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
RealmResults<Student> students = realm.where(Student.class).findAll();
students.deleteLastFromRealm();
}
}, new Realm.Transaction.OnSuccess() {
@Override
public void onSuccess() {
UIUtils.showToast("删除成功");
}
}, new Realm.Transaction.OnError() {
@Override
public void onError(Throwable error) {
UIUtils.showToast("删除失败");
}
});
break;
case 13://异步删除:后查找到数据:deleteAllFromRealm()
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
RealmResults<Student> students = realm.where(Student.class).findAll();
students.deleteAllFromRealm();
}
}, new Realm.Transaction.OnSuccess() {
@Override
public void onSuccess() {
UIUtils.showToast("删除成功");
}
}, new Realm.Transaction.OnError() {
@Override
public void onError(Throwable error) {
UIUtils.showToast("删除失败");
}
});
break;
case 14://异步删除:deleteAll()
//删除所有数据库
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
realm.deleteAll();
}
}, new Realm.Transaction.OnSuccess() {
@Override
public void onSuccess() {
UIUtils.showToast("删除成功");
}
}, new Realm.Transaction.OnError() {
@Override
public void onError(Throwable error) {
UIUtils.showToast("删除失败");
}
});
break;
case 15://异步删除:delete(xxx.class)
//删除指定的数据库
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
realm.delete(Student.class);
}
}, new Realm.Transaction.OnSuccess() {
@Override
public void onSuccess() {
UIUtils.showToast("删除成功");
}
}, new Realm.Transaction.OnError() {
@Override
public void onError(Throwable error) {
UIUtils.showToast("删除失败");
}
});
break;
case 16://推荐使用:异步查询,同步删除
students8 = mRealm.where(Student.class).findAllAsync();
students8.addChangeListener(callback);
break;
case 17://推荐使用:异步查询,异步删除
students9 = mRealm.where(Student.class).findAllAsync();
students9.addChangeListener(callback1);
break;
}
}
/** * 异步操作的监听 */ private OrderedRealmCollectionChangeListener<RealmResults<Student>> callback = new OrderedRealmCollectionChangeListener<RealmResults<Student>>() { @Override public void onChange(RealmResults<Student> collection, OrderedCollectionChangeSet changeSet) { if (changeSet == null) { //第一次异步返回一个空的变更集。 mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.delete(Student.class); } }); } else { //每次RealmResults被更新时都会被调用 } } };
/**
* 异步操作的监听
*/
private OrderedRealmCollectionChangeListener<RealmResults<Student>> callback1 = new OrderedRealmCollectionChangeListener<RealmResults<Student>>() {
@Override
public void onChange(RealmResults<Student> collection, OrderedCollectionChangeSet changeSet) {
if (changeSet == null) {
//第一次异步返回一个空的变更集。
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
realm.delete(Student.class);
}
}, new Realm.Transaction.OnSuccess() {
@Override
public void onSuccess() {
UIUtils.showToast("删除成功");
}
}, new Realm.Transaction.OnError() {
@Override
public void onError(Throwable error) {
UIUtils.showToast("删除失败");
}
});
} else {
//每次RealmResults被更新时都会被调用
}
}
};
}
Realm数据库使用教程(六):数据迁移
Demo地址:https://gitee.com/huangxiaoguo/Realm
相关文章推荐
- Realm数据库使用教程(三):查询数据
- Realm数据库使用教程(二):增加数据
- JSP初学者数据库教程(二)删除数据
- ThinkPHP学习笔记(六)使用CURD对User数据库数据进行删除和修改
- 使用sql语句删除数据库中重复的数据
- MindManager怎么使用数据库数据 MindManager数据库数据使用教程
- ASP.net 中使用Flexigrid详细教程之二-直接使用数据库数据(有图有真相)
- 使用“软删除”来删除数据库中的数据
- 使用postgreSQL DataSync 进行pg数据库升级 数据同步 升级脚本生成, postgreSQL DataSync简单教程
- 使用postgreSQL DataSync 进行pg数据库升级 数据同步 升级脚本生成, postgreSQL DataSync简单教程
- ImageKit使用教程:数据库中图像数据的显示和检索
- 使用postgreSQL DataSync 进行pg数据库升级 数据同步 升级脚本生成, postgreSQL DataSync简单教程
- 关于使用sql删除数据库重复的数据的方法整理:
- 使用postgreSQL DataSync 进行pg数据库升级 数据同步 升级脚本生成, postgreSQL DataSync简单教程
- Realm数据库读取数据时的处理:每次加载数据时,都将原有的数据删除,重新读取模型中的数据
- SQL SERVER2000教程-第五章 处理数据 第十五节 使用TRUNCATE TABLE快速删除表中的所有数据
- [翻译]Scott Mitchell 的ASP.NET 2.0数据教程之四十九:使用SqlDataSource插入、更新以及删除数据
- datagridview的使用,即时新增,更新,删除数据库数据
- 使用postgreSQL DataSync 进行pg数据库升级 数据同步 升级脚本生成, postgreSQL DataSync简单教程
- [转载] 误执行MSSQL数据库语句删除数据恢复方法--log explorer使用