Почему база данных Room теряет данные после перезапуска приложения? - PullRequest
0 голосов
/ 04 мая 2020

Я использую библиотеку Room Persistance со всеми Android Architucture Components. В приложении у меня есть 3 базы данных, но проблема только с одной. В моей MainActivity у меня есть RecyclerView, который показывает данные (даты) из DatesDatabase. При нажатии на каждый элемент открывается новое действие и отображаются все данные, относящиеся к определенной дате. Запрос в DAO:

@Query("SELECT * FROM Sorted WHERE date = :date")
LiveData<List<Sorted>> getSortedWhereDateIs(String date);

Проблема в том, что при перезапуске приложения я все еще вижу даты, которые были добавлены ранее, но нет данных, относящихся к этой дате.

Перед перезагрузкой: снимок экрана1 снимок экрана2

После перезагрузки: снимок экрана1 снимок экрана2

Код to DatesDatabase:

@Database(entities = {Dates.class}, version = 2, exportSchema = false)
public abstract class DatesDatabase extends RoomDatabase {
private static DatesDatabase instance;

public abstract DatesDao datesDao();

public static synchronized DatesDatabase getInstance(Context context){
    if (instance == null){
        instance = Room.databaseBuilder(context.getApplicationContext(),
                DatesDatabase.class, "dates_database").fallbackToDestructiveMigration()
                .build();
    }
    return instance;
}
}

Код в базу данных, который не сохраняет данные:

@Database(entities = {Sorted.class}, version = 3, exportSchema = false)
public abstract class SortedDatabase extends RoomDatabase {

private static SortedDatabase instanceSorted;

public abstract SortedDao sortedDao();

public static synchronized SortedDatabase getSortedInstance(Context context) {
    if (instanceSorted == null) {
        instanceSorted = Room.databaseBuilder(context.getApplicationContext(),
                SortedDatabase.class, "unsorted_database").fallbackToDestructiveMigration().build();
    }
    return instanceSorted;
}
}

Я попытался удалить «fallbackToDestructiveMigration ()», но у меня есть метод «deleteAll» , в этом случае отображается ошибка:

 viewModel.deleteAllDates();
 viewModel.deleteAllUnsorted();
 viewModel.deleteAllSorted();

Вот как я добавляю данные в SortedDatabase (которая удаляется):

 if (choosedMethod.equals("Eat a frog")) {
        for (int i = 0; i < eatAFrogList.size(); i++){
            Unsorted unsorted = eatAFrogList.get(i);
            String name = unsorted.getName();
            String date = unsorted.getDate();
            int timeBegin = unsorted.getTimeBegin();
            boolean attach = unsorted.isAttach();
            int category = unsorted.getCategory();
            int duration = unsorted.getDuration();
            String categoryChart = unsorted.getCategoryChart();
            Sorted sorted = new Sorted(name, timeBegin, duration, category, attach, date, 
            categoryChart);
            viewModel1.insertSorted(sorted);
        }

Я сортирую задачи класса Unsorted, хранящиеся в UnsortedDatabase , с помощью алгоритма, а затем добавьте его в базу данных SortedDatabase.

Мой адаптер для просмотра переработчика, в котором отображаются отсортированные данные:

public class SortedAdapter extends RecyclerView.Adapter<SortedAdapter.SortedViewHolder> {

private List<Sorted> list = new ArrayList<>();

@NonNull
@Override
public SortedViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
    View itemView = LayoutInflater.from(parent.getContext())
            .inflate(R.layout.tasks_layout , parent, false);
    return new  SortedAdapter.SortedViewHolder(itemView);
}

@Override
public void onBindViewHolder(@NonNull SortedViewHolder holder, int position) {
    Sorted data = list.get(position);
    holder.title.setText(data.getSortedName());
    holder.date.setText(data.getSortedDate());
    holder.category.setText(String.valueOf(data.getSortedCategory()));
    holder.attach.setText(String.valueOf(data.isSortedAttach()));
    holder.to.setText(String.valueOf(toTime(data.getSortedDuration() + data.getSortedTimeBegin())));
    holder.from.setText(String.valueOf(toTime(data.getSortedTimeBegin())));
}

public void setSortedData(List<Sorted> sortedList){
    this.list = sortedList;
    notifyDataSetChanged();
}

@Override
public int getItemCount() {
    return list.size();
}

class SortedViewHolder extends RecyclerView.ViewHolder{
    private TextView title;
    private TextView date;
    private TextView from;
    private TextView to;
    private TextView category;
    private TextView attach;

    SortedViewHolder(@NonNull View itemView) {
        super(itemView);
        title = itemView.findViewById(R.id.tv_title);
        date = itemView.findViewById(R.id.tv_date);
        from = itemView.findViewById(R.id.tv_from2);
        to = itemView.findViewById(R.id.tv_to2);
        category = itemView.findViewById(R.id.tv_category);
        attach = itemView.findViewById(R.id.tv_attach);
    }
}
}

И, наконец, действие, в котором отображаются данные:

public class ShowSortedActivity extends AppCompatActivity {

SortedViewModel viewModel;
AppPreferenceManager preferenceManager;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    preferenceManager = new AppPreferenceManager(this);
    if (preferenceManager.getDarkModeState()){
        setTheme(R.style.Dark);
    }
    else{
        setTheme(R.style.AppTheme);
    }
    setContentView(R.layout.activity_show_sorted);

    final SortedAdapter adapter = new SortedAdapter();
    RecyclerView showSorted = findViewById(R.id.show_sorted);
    showSorted.setLayoutManager(new LinearLayoutManager(this));
    showSorted.setHasFixedSize(true);
    showSorted.setAdapter(adapter);

    getSupportActionBar().setHomeAsUpIndicator(R.drawable.ic_close);
    setTitle("Sorted");

    Intent intent = getIntent();
    String currentDate = intent.getStringExtra("value");

    viewModel = new ViewModelProvider(this, ViewModelProvider.AndroidViewModelFactory.getInstance(this.getApplication())).get(SortedViewModel.class);
    try {
        viewModel.getSortedWhereDateIs(currentDate).observe(this, new Observer<List<Sorted>>() {
            @Override
            public void onChanged(List<Sorted> sorteds) {
                adapter.setSortedData(sorteds);
            }
        });
    } catch (ExecutionException e) {
        e.printStackTrace();
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
}
}

Возможно, данные не удалены, но есть проблема с отображением Это? Я не смог найти свою ошибку ... Спасибо за любую помощь.

1 Ответ

0 голосов
/ 04 мая 2020

Я думаю, проблема была в том, что я создал две базы данных с одинаковым именем "unsorted_database". Кажется, сейчас работает.

...