我有一个这样的数据库:
@Database(name = QuestionDatabase.NAME, version = QuestionDatabase.VERSION)
public class QuestionDatabase {
public static final String NAME = "QuestionDatabase"; // we will add the .db extension
public static final int VERSION = 1;
}
和这样的表:
@Table(database = QuestionDatabase.class)
public class Question extends BaseModel {
@PrimaryKey
public int localID;
@Column
public int Id;
@Column
public String Answer;
@Column
public String ImageURL;
@Column
public boolean IsFavorite;
@Column
public boolean IsSolved;
}
和asynctask从服务器中检索数据:
public class QuestionRetriever extends AsyncTask<Integer, Void, Integer> {
private Activity callerActivity;
private QuestionAdapter questionsAdapter;
private List<Question> callerQuestions;
private Integer pageSize = 10;
public QuestionRetriever(Activity callerActivity, QuestionAdapter questionsAdapter, List<Question> questions){
this.callerActivity = callerActivity;
this.questionsAdapter = questionsAdapter;
this.callerQuestions = questions;
}
@Override
protected Integer doInBackground(Integer... pageNumbers) {
Retrofit retrofit = new Retrofit.Builder()
.baseUrl("http://192.168.1.33:313/")
.addConverterFactory(GsonConverterFactory.create())
.build();
QuestionWebService service = retrofit.create(QuestionWebService.class);
Call<List<Question>> call = service.getQuestionsPaged(pageNumbers[0].toString(), pageSize.toString());
try {
Response<List<Question>> excecuted = call.execute();
List<Question> questions = excecuted.body();
FastStoreModelTransaction
.insertBuilder(FlowManager.getModelAdapter(Question.class))
.addAll(questions)
.build();
callerQuestions.addAll(questions);
callerActivity.runOnUiThread(new Runnable() {
@Override
public void run() {
questionsAdapter.notifyDataSetChanged();
}
});
//Get TotalQuestionCount if not yet
if (((StatefulApplication) callerActivity.getApplication()).getQuestionCount() == -1){
Call<Integer> call2 = service.getQuestionsSize();
try {
((StatefulApplication) callerActivity.getApplication()).setQuestionCount(call2.execute().body());
} catch (IOException e) {
e.printStackTrace();
}
}
} catch (IOException e) {
e.printStackTrace();
}
catch (Exception e){
e.printStackTrace();
}
return 1;
}
@Override
protected void onPreExecute() {
super.onPreExecute();
//TODO: show loader
}
@Override
protected void onPostExecute(Integer result) {
super.onPostExecute(result);
//TODO: hide loader
}
}
正如你所看到的那样,在运行FastStoreModelTransaction
之后,每件事情都显得确定无所不及。没有错误。
初始化作业在启动画面活动中完成,如下所示:
private void initializeEveryRun() {
//Initializing DBFlow
//DBFlow needs an instance of Context in order to use it for a few features such as reading from assets, content observing, and generating ContentProvider.
//Initialize in your Application subclass. You can also initialize it from other Context but we always grab the Application Context (this is done only once).
FlowManager.init(new FlowConfig.Builder(getApplicationContext()).build());
}
任何关于应该导致此问题或任何解决方案的想法? TG
答案 0 :(得分:1)
我找到了答案!!!
正如您在模型中看到的那样,Id
是从服务器检索的对象的标识符,LocalId
是本地存储的自动增量标识符。这是问题所在。我已将Id
字段用作主键,并为服务器端标识添加了一个名为OnlineId
的字段,现在一切正常。
这是一个错误还是我错了?
TG
答案 1 :(得分:1)
这不是执行交易,它只是创建交易。
你可以看到这个测试DBFlow - FastModelTest.kt。
FastStoreModelTransaction
.insertBuilder(FlowManager.getModelAdapter(Question.class))
.addAll(questions)
.build();
您必须执行以下交易:
FlowManager.getDatabase(QuestionDatabase.class).executeTransaction(<<YourTransaction>>);
否则,如果您已经拥有DatabaseWrapper实例,则可以执行<<YourTransaction>>.excute(<<YourDatabaseWrapper>>);
。