android - 在其中添加对象后, Realm 对象不更新

标签 android database sql-update realm realm-list

有人能给我解释一下吗? 这是我的代码,之后,我将显示日志。事实上,我有一个对象列表。我记录它的大小:1。我清除它,变成 0。我在其中添加对象,它仍然是 0。

这是我的代码:

 Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE" + index);
                    RealmList<TripStep> tripsteps = psTrip.getTripSteps();
                    Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE2:" + psTrip.getTripSteps().size());
                    realmActive.beginTransaction();
                    TripStep tripStep = realmActive.copyToRealmOrUpdate(updateStepResponse.getStep());
                    realmActive.commitTransaction();
                    Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE3 + index is:" + index);
                    realmActive.beginTransaction();
                    tripsteps.set(index, tripStep);
                    realmActive.commitTransaction();
                    Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE4");
                    if (isRoaming) {
                        if ((tripsteps.size() - 2 == index) && !Utils.hasStarted(PSNewJourneyActivity.this)) {
                            realmActive.beginTransaction();
                            tripsteps.get(tripsteps.size() - 1).setTravelMode(updateStepResponse.getStep().getTravelMode());
                            realmActive.commitTransaction();
                        }
                    }
                    Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE5 tripsteps not in pstrip:" + tripSteps.size());
                    Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE5 tripsteps not in pstrip before:" + psTrip.getTripSteps().size());
                    realmActive.beginTransaction();
                    psTrip.getTripSteps().clear();
                    realmActive.commitTransaction();
                    Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE5 tripsteps not in pstrip AFTER CLEAR:" + psTrip.getTripSteps().size());
                    realmActive.beginTransaction();
                    for (TripStep tripStep1 : tripsteps){
                        psTrip.getTripSteps().add(tripStep1);
                    }
                    realmActive.commitTransaction();
                    realmActive.beginTransaction();
                    realmActive.copyToRealmOrUpdate(psTrip);
                    realmActive.commitTransaction();
                    Log.i("", "update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE6 tripstep size:" + psTrip.getTripSteps().size());
                    Handler han = new Handler();
                    han.postDelayed(new Runnable() {
                        @Override
                        public void run() {
                            continueInit(true, true);
                            ProgressForMap(true);
                        }
                    }, mapDelay);

这是我的日志:

update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE0
09-09 10:12:11.219  32740-32740/nl.hgrams.passenger I/﹕ update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE2:1
09-09 10:12:11.251  32740-32740/nl.hgrams.passenger I/﹕ update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE3 + index is:0
09-09 10:12:11.257  32740-32740/nl.hgrams.passenger I/﹕ update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE4
09-09 10:12:11.257  32740-32740/nl.hgrams.passenger I/﹕ update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE5 tripsteps not in pstrip:1
09-09 10:12:11.257  32740-32740/nl.hgrams.passenger I/﹕ update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE5 tripsteps not in pstrip before:1
09-09 10:12:11.264  32740-32740/nl.hgrams.passenger I/﹕ update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE5 tripsteps not in pstrip AFTER CLEAR:0
09-09 10:12:11.277  32740-32740/nl.hgrams.passenger I/﹕ update step pitstop 1 BEFORE TEST FOR ACTIVE -> ACTIVE6 tripstep size:0

最佳答案

这有点令人费解。我要说的一件事是:

                    // this part makes sense
                    realmActive.beginTransaction(); 
                    for (TripStep tripStep1 : tripsteps){
                        psTrip.getTripSteps().add(tripStep1);
                    }
                    realmActive.commitTransaction();

                    // why are you then doing this?
                    //realmActive.beginTransaction();
                    //realmActive.copyToRealmOrUpdate(psTrip);
                    //realmActive.commitTransaction();

据我所知,只有第一部分就足够了,第二部分什么都不做。

更新:

刚刚注意到您的变量 tripsteps 已在此处分配:

RealmList<TripStep> tripsteps = psTrip.getTripSteps();

然后您稍后执行此操作:

psTrip.getTripSteps().clear();

tripstepspsTrip.getTripSteps() 指向同一个对象,因此当您调用 psTrip.getTripSteps().clear(); 您还清除了 tripsteps

所以此时 tripsteps 中将没有任何内容:

for (TripStep tripStep1 : tripsteps){ // tripsteps.size() == 0
    psTrip.getTripSteps().add(tripStep1);
}

我认为您需要“深度复制”您的数组列表:

这是错误的:

RealmList<TripStep> tripsteps = psTrip.getTripSteps();

改为这样做:

RealmList<TripStep> tripsteps = cloneList(psTrip.getTripSteps());

public List<TripStep> cloneList(RealmList<TripStep> list) {
    List<TripStep> clone = new ArrayList<TripStep>(list.size());
    for(TripStep item : list){
        clone.add(new TripStep(item));
    }

    return clone;
}

您需要在 TripStep 类中创建一个可以从另一个实例复制的构造函数:

class TripStep
{
    public TripStep()
    { ... } // Regular constructor

    public TripStep(TripStep cloneFrom) {
        // Copy all the fields of TripStep.
    }
}

关于android - 在其中添加对象后, Realm 对象不更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32474355/

相关文章:

mysql - mysql一条语句同时更新两张表

java - Android Studio com.google.wireless.android.sdk.stats.IntellijIndexingStats

android - 获取图像

android - 停止音乐和服务

mysql - 在 CentOS 6.2 中将 MySQL 版本从 5.1 更新到 5.5

sql - 更新子句中缺少的记录

java - Android 中用于更新数据库的 SQLite 语句不起作用

database - 在数据库中存储年龄的最佳方式,无 DOB

java - Java应用程序无法连接到MySQL数据库

MySQL:遍历一个表并更新另一个表?