我试图根据查询从Realm.io数据库中删除最后一个Object,如下所示:
Realm realm = Realm.getInstance(this);
final RealmResults<RealmCustomLocation> databaseLocations = realm.where(RealmCustomLocation.class).findAllSorted("timeStamp", RealmResults.SORT_ORDER_DESCENDING);
if(databaseLocations.size() >= 4){
realm.beginTransaction();
databaseLocations.removeLast();
realm.commitTransaction();
}
这与Realm.io instructions关于删除的内容完全相同:
realm.beginTransaction();
result.removeLast();
realm.commitTransaction()
但是当我执行代码时,它总是以RealmException打破
io.realm.exceptions.RealmException: Removing object is not supported.
然后我查看了RealmResults.java的源代码,我发现了这个: 所以难怪它一直崩溃,removeLast()什么都不做,只抛出一个错误!
所以我的问题是:如何从数据库中删除对象呢?!
我在Android上使用realm.io 0.77(编译&#39; io.realm:realm-android:0.77.0&#39;)。
感谢您对此的帮助!
答案 0 :(得分:7)
我已联系Realm.io支持,等待回答。与此同时:
RealmCustomLocation location = databaseLocations.get(databaseLocations.size() - 1);
location.removeFromRealm();
相当于
databaseLocations.removeLast()
所以它可以用作解决方法。
编辑:支持告诉我他们正在为将来的版本修复它,并建议同时使用我发布的解决方法。
答案 1 :(得分:1)
如果你想删除所有对象,那么我会创建一个这样的while循环:
while (location.size() > 0) {
location.removeLast();
}