Realm数据库使用教程(四):更新数据
2017-12-20 13:54
225 查看
Realm数据库使用教程(三):查询数据
异步操作:executeTransactionAsync修改
重要:使用查询语句得到数据,然后将内容修改
Realm数据库使用教程(五):删除数据
Demo地址:https://gitee.com/huangxiaoguo/Realm
activity全部代码:
Realm数据库使用教程(五):删除数据
Demo地址:https://gitee.com/huangxiaoguo/Realm
更新数据
同步操作:executeTransaction修改mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { Men men = realm.where(Men.class).findFirst(); men.setName("我把第一个同步修改了"); } });
异步操作:executeTransactionAsync修改
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { Men men = realm.where(Men.class).findFirst(); men.setName("我把第一个,异步修改了"); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("修改完成"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("修改失败"); } });
@Override protected void onDestroy() { super.onDestroy(); if (realmAsyncTask != null && !realmAsyncTask.isCancelled()) { realmAsyncTask.cancel(); } if (mRealm != null && !mRealm.isClosed()) { mRealm.close(); } }
重要:使用查询语句得到数据,然后将内容修改
//这里需要注意,姿势不对会出错(出现漏修改情况) RealmResults<Men> all = mRealm.where(Men.class) .findAll(); // mRealm.beginTransaction(); // for (int i = 0; i < all.size(); i++) { // all.get(i).setName("使用查询语句后就可以修改"); // } // mRealm.commitTransaction(); //到这里是不行的,因为迭代器修改时会移除,所以导致隔一修改情况, // 需要一下操作 mRealm.beginTransaction(); OrderedRealmCollectionSnapshot<Men> menSnapshot = all.createSnapshot(); for (int i = 0; i < menSnapshot.size(); i++) { menSnapshot.get(i).setName("使用查询语句后就可以修改!"); } mRealm.commitTransaction();
Realm数据库使用教程(五):删除数据
Demo地址:https://gitee.com/huangxiaoguo/Realm
activity全部代码:
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.OrderedRealmCollectionSnapshot;
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.Men;
import tsou.com.simple.realmtest.utils.UIUtils;
public class UpdataActivity extends AppCompatActivity implements AdapterView.OnItemClickListener {
private ListView mListview;
private List<String> titles = new ArrayList<>();
private Realm mRealm;
private RealmAsyncTask realmAsyncTask;
@Override
protected void onDestroy() {
super.onDestroy();
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("同步操作:executeTransaction修改");
titles.add("异步操作:executeTransactionAsync修改");
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://同步操作:executeTransaction修改
mRealm.executeTransaction(new Realm.Transaction() {
@Override
public void execute(Realm realm) {
Men men = realm.where(Men.class).findFirst();
men.setName("我把第一个同步修改了");
}
});
break;
case 1://异步操作:executeTransactionAsync修改
realmAsyncTask = mRealm.executeTransactionAsync(new Realm.Transaction() { @Override public void execute(Realm realm) { Men men = realm.where(Men.class).findFirst(); men.setName("我把第一个,异步修改了"); } }, new Realm.Transaction.OnSuccess() { @Override public void onSuccess() { UIUtils.showToast("修改完成"); } }, new Realm.Transaction.OnError() { @Override public void onError(Throwable error) { UIUtils.showToast("修改失败"); } });
break;
case 2://重要:使用查询语句得到数据,然后将内容修改//这里需要注意,姿势不对会出错(出现漏修改情况) RealmResults<Men> all = mRealm.where(Men.class) .findAll(); // mRealm.beginTransaction(); // for (int i = 0; i < all.size(); i++) { // all.get(i).setName("使用查询语句后就可以修改"); // } // mRealm.commitTransaction(); //到这里是不行的,因为迭代器修改时会移除,所以导致隔一修改情况, // 需要一下操作 mRealm.beginTransaction(); OrderedRealmCollectionSnapshot<Men> menSnapshot = all.createSnapshot(); for (int i = 0; i < menSnapshot.size(); i++) { menSnapshot.get(i).setName("使用查询语句后就可以修改!"); } mRealm.commitTransaction();
break;
}
}
}
Realm数据库使用教程(五):删除数据
Demo地址:https://gitee.com/huangxiaoguo/Realm
相关文章推荐
- MySQL的源码安装及使用UDFs进行数据自动更新的教程
- MySQL的源码安装及使用UDFs进行数据自动更新的教程
- [翻译]Scott Mitchell 的ASP.NET 2.0数据教程之四十九:使用SqlDataSource插入、更新以及删除数据
- 【EntityFramework系列教程六,翻译】在ASP.NET MVC程序中使用EntityFramework对相关数据进行更新
- ASP.NET基础教程-使用CommandBuilder对象自动生成SQL语句对数据进行批量更新
- [教程]使用ADOKeycap插入,更新,删除数据
- 使用ComponentArt.WebUI.for.Asp.net.3.0的TreeView控件实现数据驱动的无限级分类管理[图文教程]
- 使用Quest Central导入导出数据教程
- [翻译] Scott Mitchell 的ASP.NET 2.0数据操作教程之七:使用DropDownList过滤的主/从报表
- [转]PHP之中使用共享内存进行高速数据更新的一种方案
- [翻译] Scott Mitchell 的ASP.NET 2.0数据操作教程之八:使用两个DropDownList过滤的主/从报表
- [翻译]Scott Mitchell 的ASP.NET 2.0数据教程之十三:在DetailsView控件中使用TemplateField
- Scott Mitchell 的ASP.NET 2.0数据教程之十三:在DetailsView控件中使用TemplateField
- Scott Mitchell 的ASP.NET 2.0数据操作教程之七:使用DropDownList过滤的主/从报表
- 使用EditCommandColumn更新数据遇到的问题
- Scott Mitchell 的ASP.NET 2.0数据教程之十二:在GridView控件中使用TemplateField
- Scott Mitchell 的ASP.NET 2.0数据教程之十四:使用FormView 的模板
- 使用 DataAdapter 和 DataSet 更新数据库
- (原创)方便的使用单击和双击更新DataGrid中的数据的例子
- [翻译]Scott Mitchell 的ASP.NET 2.0数据教程之十四:使用FormView 的模板