Была похожая проблема. Решено путем хранения базы данных как синглтона (не DAO)

аюсь выяснить в приведенном ниже коде, почему наблюдаемые LiveData в Room не дают мне новых изменений, когда я заполняю базу данных новыми данными.

Это помещено в метод onCreate моей деятельности:

shiftsViewModel = ViewModelProviders.of(this).get(ShiftsViewModel.class);
shiftsViewModel
            .getShifts()
            .observe(this, this::populateAdapter);

Это метод populateAdapter:

private void populateAdapter(@NonNull final List<Shift> shifts){

    recyclerView.setAdapter(new SimpleItemRecyclerViewAdapter(shifts));
}

У меня также есть следующий код, который заполняет базу данных (я использую RxJava для выполнения работы над потоком ввода-вывода, поскольку Room требуется, чтобы ее код вызывался вне основного потока):

@Override
public Observable<List<Shift>> persistShifts(@NonNull final List<Shift> shifts){

    return Observable.fromCallable(() -> {

        appDatabase.getShiftDao().insertAll(shifts);
        return shifts;
    })
    .subscribeOn(Schedulers.io())
    .observeOn(AndroidSchedulers.mainThread());
}

Проблема у меня возникает, когда я вызываю persistShifts после того, как начинаю наблюдать за моей shiftsViewModel. Я ожидаю, что мой наблюдатель (LiveData) будет вызван всеми новыми добавленными сменами. Оказывается, наблюдатель срабатывает, но вместо него возвращается пустой список смен. Единственный способ заставить его работать, если я оставляю активность (поэтому уничтожаю текущую ViewModel) и снова захожу. На этот раз LiveData viewModel дает мне все ранее сохраненные сдвиги, как и ожидалось.

Вот остальная часть кода:

@Entity
public class Shift{

   @PrimaryKey
   private long id;

   private String start;
   private String end;
   private String startLatitude;
   private String startLongitude;
   private String endLatitude;
   private String endLongitude;
   private String image;
   ...

DAO:

@Dao
public interface ShiftDAO {

   @Query("SELECT * FROM shift")
   LiveData<List<Shift>> getAll();

   @Query("SELECT * FROM shift WHERE id = :id")
   LiveData<Shift> getShiftById(long id);

   @Insert(onConflict = OnConflictStrategy.REPLACE)
   void insertAll(List<Shift> shifts);
}

ViewModel:

public class ShiftsViewModel extends AndroidViewModel{

   private final ISQLDatabase sqlDatabase;

   private MutableLiveData<Shift> currentShift;
   private LiveData<List<Shift>> shifts;
   private boolean firstTimeCreated;


   public ShiftsViewModel(final Application application){

      super(application);

      this.sqlDatabase = ((ThisApplication) application).getSQLDatabase();
      this.firstTimeCreated = true;
   }

   public MutableLiveData<Shift> getCurrentlySelectedShift(){

      if(currentShift == null){
         currentShift = new MutableLiveData<>();
      }

      return currentShift;
   }

   public LiveData<List<Shift>> getShifts() {

      if(shifts == null){
         shifts = sqlDatabase.queryAllShifts();
      }

     return shifts;
   }

   public void setCurrentlySelectedShift(final Shift shift){

      currentShift = getCurrentlySelectedShift();

      currentShift.setValue(shift);
   }

   public boolean isFirstTimeCreated(){
      return firstTimeCreated;
   }

   public void alreadyUsed(){
      firstTimeCreated = false;
   }
}

Почему я не получаю список изменений, которые я сохраняю в обратном вызове наблюдения () сразу?

Ответы на вопрос(1)

Ваш ответ на вопрос