当前位置: 首页 > 知识库问答 >
问题:

SQLite MVVM返回

拓拔骁
2023-03-14

我有一个使用MVVM构建的应用程序。我已成功地将应用程序插入SQLite数据库。我现在尝试在插入完成后获取数据库中的rowId,以便在后续活动中可以对该行进行更新。

我完全理解在DAO中将Void更改为Long的部分,但我不知道如何在活动级别实际访问该Long,并将其保存到一个变量中,该变量可以从一个活动发送到另一个活动。加价。下面是代码示例。

表/实体类:

@Entity(tableName = "CbtTable")
public class CbtTable {

@PrimaryKey(autoGenerate = true)
private long cbtId;

存储库类:

public class CbtRepository {

private CbtDao cbtDao;
private LiveData<List<CbtTable>> cbtData;
private FeelingFitDatabase mFeelingFitDatabase;

public CbtRepository(Application application) {
    mFeelingFitDatabase = FeelingFitDatabase.getInstance(application);
    cbtDao = mFeelingFitDatabase.getCbtDao();
    cbtData = cbtDao.getCbtData();
}


public void insertCbt(CbtTable cbtTable){

    new InsertCbtAsyncTask(cbtDao).execute(cbtTable);

}

@Dao
public interface CbtDao {

@Insert(onConflict = REPLACE)
public long insertAutoThought(CbtTable cbtTable);

@Query("UPDATE CbtTable SET automaticThought = :automaticThought WHERE cbtId = :cbtId")
void updateAutoThought(long cbtId, String automaticThought);

@Query ("UPDATE CbtTable SET twistedThinking = :twistedThinking WHERE cbtId = :cbtId")
void updateTwistedThinking(long cbtId, int twistedThinking);

ViewModel类:

public class CbtViewModel extends AndroidViewModel {

private CbtRepository cbtRepository;
private LiveData<List<CbtTable>> cbtData;

public CbtViewModel(@NonNull Application application) {
    super(application);
    cbtRepository = new CbtRepository(application);
    cbtData = cbtRepository.getCbtData();
}

public void insert(CbtTable cbtTable){
    cbtRepository.insertCbt(cbtTable);
}

public void updateTwistedThinking(CbtTable cbtTable){
    cbtRepository.updateTwistedThinking(cbtTable);
}

异步任务类:

public class InsertCbtAsyncTask extends AsyncTask<CbtTable, Void, Void> {

private CbtDao mCbtDao;

public InsertCbtAsyncTask(CbtDao cbtDao){
    mCbtDao = cbtDao;
}


@Override
protected Void doInBackground(CbtTable... cbtTables) {
    mCbtDao.insertAutoThought(cbtTables[0]);
    return null;
}

活动方法:

 private void saveAutomaticThought(){

    CbtTable cbtTable = new CbtTable(userId, automaticThoughtString, twistedThinking, challengeThoughtString, rationalThoughtString, postedWorkout);
    cbtViewModel.insert(cbtTable);
    long cbtId = cbtTable.getCbtId();

    // Sends the user to the WorkoutAutomaticThoughtActivity page
    Intent intent = new Intent(this, WorkoutTwistedThinkingActivity.class);
    intent.putExtra("cbtId", cbtId);

使用活动中的上述代码,cbtId将存储为0,因此无法工作。这是我正在开发的免费心理健康应用程序,旨在帮助人们,所以我越早解决这个问题,我就越早推出这个应用程序。我将非常感谢任何帮助调试此问题并使其工作。

共有1个答案

晏弘雅
2023-03-14

我不建议你使用AsynWork。但是你可以做这样的事情。

让InsertCbtAsyncWork接受回调作为参数,并在它具有插入的ID后调用它:

public class InsertCbtAsyncTask extends AsyncTask<CbtTable, Void, Void> {
    private CbtDao mCbtDao;
    private long id;
    private DoWithId callback;

    public InsertCbtAsyncTask(CbtDao cbtDao, DoWithId callback){
        mCbtDao = cbtDao;
        this.callback = callback;
    }

    @Override
    protected Void doInBackground(CbtTable... cbtTables) {
        id = mCbtDao.insertAutoThought(cbtTables[0]);
        return null;
    }

    @Override
    protected void onPostExecute(Void aVoid) {
        callback.doWithId(id);
    }

    interface DoWithId {
        public void doWithId(long id);
    }

}

然后,在调用该类时,可以将回调作为参数传递。例如:

    DoWithId callback = new DoWithId() {
        @Override
        public void doWithId(long id) {
            launchIntentWithId(id)
        }
    };
    new InsertCbtAsyncTask(cbtDao, callback).execute(cbtTable);

launchIntentWithId()如下所示:

public launchIntentWithId(long cbtId) {
    Intent intent = new Intent(this, WorkoutTwistedThinkingActivity.class);
    intent.putExtra("cbtId", cbtId);
    startActivity(Intent);
}

这段代码没有经过测试,可能不完整,但它应该给你一个完整的想法。

 类似资料:
  • 问题内容: 我在使用Ajax时遇到问题。 问题是,在获得ajax响应之前,它会返回cnt。因此它总是返回NULL。 有没有办法使正确的返回响应值? 谢谢! 问题答案: 由于AJAX请求是异步的,因此您的cnt变量将在请求返回并调用成功处理程序之前返回。 我建议重构您的代码以解决此问题。 一种方法是从AJAX请求的成功处理程序中调用调用了GetGrantAmazonItemCnt()的任何函数,此方

  • 问题内容: 例如我有一个功能: 我怎样才能返回AJAX后得到的? 问题答案: 因为请求是异步的,所以您无法返回ajax请求的结果(而同步ajax请求是一个 糟糕的 主意)。 最好的选择是将自己的回调传递给f1 然后,您将像这样致电:

  • 我想在下面返回JSON。 {“名字”:“杰基”} 新来的春靴在这里。1天大。有没有合适的方法可以做到这一点?

  • 问题内容: 我创建了一个自定义错误类型来包装错误,以便更轻松地在Golang中进行调试。当有打印错误时它可以工作,但是现在引起了恐慌。 演示版 当我调用一个函数时,它不会返回错误,我仍然应该能够包装该错误。 预期的行为是,如果错误为nil,则应该简单地忽略它,不幸的是,它会做相反的事情。 我希望它能打印出来。而是即使错误为nil也会打印。 问题答案: 正在将err变量与nil进行比较,但实际上它是

  • 问题内容: 有人可以向我解释为什么返回类型 只是返回类型 我不明白为什么地图会映射到一个以上的值。TIA。 问题答案: 它返回具有 相同 名称的控件的所有参数值。 例如: 要么 任何选中/选择的值都将以以下形式出现: 对于表中的多个选择它也很有用: 与…结合

  • 问题内容: 我有一类这样的方法: 我如何在另一个类中调用此方法? 问题答案: 1. 如果要从中调用该方法的类位于同一包中,则创建该类的实例并调用该方法。 2. 使用 3. 最好有个赞等等。 例如:

  • 这三个函数的返回类型提示有什么不同吗? 他们都应该有< code>- 提问的动机是这个问题,这个很好的答案,以及我正在学习类型提示的事实。

  • 我使用类型TreeMap定义了一个集合 我想返回与包含给定字符串值的列表配对的字符串(TreeMap键)。例如,我有一个字符串“bob”存储在列表中的一对中,我想返回与“bob”所在的对列表相关联的Treemap的键(字符串)。我将如何执行此操作?