我刚刚完成了关于Room Database的codelab课程,但似乎无法将数据加载到表中。
我已将这门课程应用到我的项目中。我的项目在recyclerview中显示一组项目,当用户按下recyclerview中某个项目的按钮时,它将被添加到房间数据库中创建的表中。
我使用sqlite db explorer打开了Room db,其中包含来自设备资源管理器的文件。我可以看到已经创建了数据库以及我正试图插入的表,但是表中没有数据。
这是我的recyclerview的onBindViewHolder
holder.QtyAdd.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//Code to build product
new PopulateDB(RoomDatabase.getDatabase(context), product);
}
});
我已经检查并确保产品不为空。
这是用于填充数据库的AsyncTask,也在adpater中
private static class PopulateDB extends AsyncTask<Void,Void,Void>{
private final CartDao cartDao;
private final Product product;
PopulateDB(RoomDatabase database, Product product){
cartDao = database.CartDao();
this.product = product;
}
@Override
protected Void doInBackground(Void... voids) {
cartDao.insert(product);
return null;
}
}
这是我的刀
@Dao
public interface CartDao {
@Insert(onConflict = OnConflictStrategy.REPLACE)
void insert(Product productCart);
@Query("DELETE FROM promotion_cart")
void clearCart();
@Query("SELECT * from promotion_cart")
LiveData<List<PromotionProduct>> getAllPromotionCartItems();
}
我试图在cart片段中显示这个表数据,并且在数据准备好后使用这个方法来显示它。
cartViewModel.getAllCartItems().observe(this, new Observer<List<Product>>() {
@Override
public void onChanged(@Nullable List<Product> products) {
cartAdapter.setProductCartList(products);
}
});
我检查过这个适配器,列表大小为0。
如果你需要更多的信息,请务必询问,
谢谢你的时间/