gpt4 book ai didi

java - 如何使用存储库和 View 模型更新房间数据库中的字段

转载 作者:行者123 更新时间:2023-12-02 05:46:40 25 4
gpt4 key购买 nike

我按照此 guide from code labs 创建了一个房间数据库它利用存储库来:

A Repository manages query threads and allows you to use multiple backends. In the most common example, the Repository implements the logic for deciding whether to fetch data from a network or use results cached in a local database.

我按照指南操作,现在可以创建实体并检索数据。我什至更进一步,在指南的范围之外创建了另一个完整的实体。

但是我找不到很多使用这种 MVVM(?) 风格的资源,所以我很难真正理解存储库。现在我想更新一个字段。只有一个,好像我能够做到其余的应该类似。

我想更新一个名为 dartshit 的字段,并且我为此创建了 dao 方法:

@Query("更新 AtcUserStats SET dartsHit = :amount WHERE userName = :userName") void UpdateHitAmount(int amount, String userName);

我有一个存储库,我假设我将其用于所有实体:

public class UsersRepository {

private UsersDao mUsersDao;
private AtcDao mAtcDao;
private LiveData<List<Users>> mAllUsers;
private LiveData<List<AtcUserStats>> mAllAtc;
private AtcUserStats mAtcUser;

UsersRepository(Application application) {
AppDatabase db = AppDatabase.getDatabase(application);
mUsersDao = db.usersDao();
mAtcDao = db.atcDao();
mAllUsers = mUsersDao.fetchAllUsers();
mAllAtc = mAtcDao.getAllAtcStats();
}

LiveData<List<Users>> getAllUsers() {
return mAllUsers;
}

LiveData<List<AtcUserStats>> getAllAtcStats() {
return mAllAtc;
}

LiveData<AtcUserStats> getAtcUser(String username) {

return mAtcDao.findByName(username);
}

public void insert (Users user) {
new insertAsyncTask(mUsersDao).execute(user);
}

public void insertAtc (AtcUserStats atc) {
new insertAsyncAtcTask(mAtcDao).execute(atc);
}

private static class insertAsyncTask extends AsyncTask<Users, Void, Void> {

private UsersDao mAsyncTaskDao;

insertAsyncTask(UsersDao dao) {
mAsyncTaskDao = dao;
}

@Override
protected Void doInBackground(final Users... params) {
mAsyncTaskDao.insertNewUser(params[0]);
return null;
}
}

private static class insertAsyncAtcTask extends AsyncTask<AtcUserStats, Void, Void> {

private AtcDao mAsyncTaskDao;

insertAsyncAtcTask(AtcDao dao) {
mAsyncTaskDao = dao;
}

@Override
protected Void doInBackground(final AtcUserStats... params) {
mAsyncTaskDao.insertNewAtcUser(params[0]);
return null;
}
}
}

我的问题是如何为我尝试在此存储库中运行的更新查询创建 AsyncTask?

这是迄今为止我通过广泛复制插入存储库方法所获得的内容:

private class updateHitAsyncTask {

private AtcDao mAsyncTaskDao;

public updateHitAsyncTask(AtcDao mAtcDao) {

mAsyncTaskDao = mAtcDao;
}

protected Void doInBackground(int amount, String name) {
mAsyncTaskDao.UpdateHitAmount(amount, name);
return null;
}
}

不正确的是,我收到了 llegalStateException: Cannot access database on the main thread because it might likely lock the UI for a long period of time. 错误。但我认为这个 AsyncTask 应该解决这个问题?

这是我的 View 模型中的更新方法,报告 0 个错误:

  void updateHitAmount (int amount, String name) {
mRepository.updateAtcHits(amount, name);
}

这是 UI 代码,我实际上试图将所有这些结合在一起,我怀疑一定有更好的方法,使用 onChanged 来简单地更新字段,但我再次努力在谷歌上找到关于存储库的任何建议方法:

   private void callOnChanged() {

mAtcViewModel = ViewModelProviders.of(this).get(AtcViewModel.class);

mAtcViewModel.getAllUsers().observe(this, new Observer<List<AtcUserStats>>() {
@Override
public void onChanged(@Nullable final List<AtcUserStats> atc) {
// Update the cached copy of the users in the adapter.


for (int i = 0; i < atc.size(); i++) {
if (atc.get(i).getUserName().equals(mUser)) {
mAtcViewModel.updateHitAmount(55, mUser);
//atc.get(i).setDartsHit(55);
Log.d("id", String.valueOf(userSelected.getId()));
}
}
}
});

如何在后台线程上使用此方法更新字段?

最佳答案

由于这个答案而弄清楚了here 。这主要是因为我对AsyncTask缺乏了解。本质上,我需要创建一个对象并以这种方式传递数据,然后在后台执行:

 private static class MyTaskParams {
int amount;
String name;

MyTaskParams(int amount, String name) {
this.amount = amount;
this.name = name;
}
}

public void updateAtcHits (int amount, String name) {

MyTaskParams params = new MyTaskParams(amount,name);
new updateHitAsyncTask(mAtcDao).execute(params);
}

private class updateHitAsyncTask extends AsyncTask<MyTaskParams,Void,Void>{

private AtcDao mAsyncTaskDao;

public updateHitAsyncTask(AtcDao mAtcDao) {

mAsyncTaskDao = mAtcDao;
}

@Override
protected Void doInBackground(MyTaskParams... myTaskParams) {
int amount =myTaskParams[0].amount;
String name = myTaskParams[0].name;
mAsyncTaskDao.UpdateHitAmount(amount, name);
return null;
}
}

关于java - 如何使用存储库和 View 模型更新房间数据库中的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56088451/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com