代码之家  ›  专栏  ›  技术社区  ›  Demonic218

插入数据后,房间数据库表仍然为空

  •  0
  • Demonic218  · 技术社区  · 7 年前

    我刚刚完成了关于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。

    如果你需要更多的信息,请务必询问, 谢谢你的时间/

    1 回复  |  直到 7 年前
        1
  •  3
  •   CommonsWare    7 年前
    new PopulateDB(RoomDatabase.getDatabase(context), product);
    

    您正在创建 AsyncTask . 你从来没有执行过,所以 doInBackground() 不是在跑步。您可以通过在 做背景() 或将日志添加到 做背景() .

    为了修好它, execute() 你的 异步任务 .

    另外,请注意,由于您没有使用 onPostExecute() ,使用的价值很小 异步任务 这里,与使用任何其他线程解决方案相比( Thread , Executor ,RxJava等)。