我正在尝试使用RX2和房间从表中更新一个值。
我的物品是
@Entity(tableName = "myCustomTable")
public class MyItem {
@NonNull
@PrimaryKey
@ColumnInfo(name = "item_id")
@SerializedName("item_id")
private Long item_id;
@ColumnInfo(name = "name")
@SerializedName("name")
private String name;
@ColumnInfo(name = "country")
@SerializedName("country")
private String value;
@SerializedName("image")
@ColumnInfo(name = "image")
private String image;
@ColumnInfo(name = "latitude")
@SerializedName("latitude")
private Double latitude;
@ColumnInfo(name = "longitude")
@SerializedName("longitude")
private Double longitude;
@ColumnInfo(name = "valid")
private boolean valid;
public MyItem (Long item_id, String name, String value, String image, Double latitude, Double longitude, boolean valid) {
this.item_id = item_id;
this.name = name;
this.value = value;
this.image = image;
this.latitude = latitude;
this.longitude = longitude;
this.valid = true;
}
public boolean isValid() {
return valid;
}
public Long getItem_id() {
return item_id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public String getImage() {
return image;
}
public void setImage(String image) {
this.image = image;
}
public Double getLatitude() {
return latitude;
}
public Double getLongitude() {
return longitude;
}
}
我的查询是这样:
@Dao
public interface CustomDao {
@Insert(onConflict = OnConflictStrategy.REPLACE)
void insertItem(MyItem item);
@Query("UPDATE myCustomTable SET valid = :isValid WHERE item_id= :id")
void flagQueued(long id, boolean isValid);
}
默认情况下,有效值为true;
这将被数据库实现调用并转换为可完成
public class LocalDataSource implements DataSource {
private CustomDao customDao;
@Inject
public LocalPupilDataSource(CustomDao customDao) {
this.customDao = customDao;
}
public Completable flagQueued(long id) {
return Completable.fromAction(() -> customDao.flagQueued(id,false));
}
}
最后,我由订户调用flagQueued方法。该订户正在成功完成响应。
mCompositeDisposable.add(viewModel.deleteItem(id)
.subscribeOn(schedulerProvider.computation())
.observeOn(schedulerProvider.ui())
.subscribe(() -> Snackbar.make(getActivity().findViewById(R.id.main_layout),
R.string.user_removed, Snackbar.LENGTH_SHORT).show(), error -> Timber.e(error,error.getMessage()) ) );
不幸的是,该值未更新。当然,该ID存在于表中。
任何建议将不胜感激。
答案 0 :(得分:1)
发现了问题。经过数小时的调试。
出于某种原因,我在构造函数this.valid = true;
上分配的默认值破坏了QUERY。
因此解决方案只是删除故障值,并在我要将其插入表中时将所需的值分配给Item。
我可以在此发布帖子的房间有GitHub存储库吗?