Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/api/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 插入数据后,文件室数据库表仍为空_Android_Android Room - Fatal编程技术网

Android 插入数据后,文件室数据库表仍为空

Android 插入数据后,文件室数据库表仍为空,android,android-room,Android,Android Room,我刚刚完成了关于Room数据库的codelab课程,但似乎无法将数据加载到表中 我已将这门课程应用到我的项目中。我的项目在recyclerview中显示一组项目,当用户按下recyclerview中某个项目上的按钮时,它将被添加到房间数据库中创建的表中 我已经使用sqlite db explorer打开了房间db,其中包含设备资源管理器中的文件。我可以看到数据库和我试图插入的表都已创建,但表中没有数据 这是我的recyclerview的onBindViewHolder holder.QtyAdd

我刚刚完成了关于Room数据库的codelab课程,但似乎无法将数据加载到表中

我已将这门课程应用到我的项目中。我的项目在recyclerview中显示一组项目,当用户按下recyclerview中某个项目上的按钮时,它将被添加到房间数据库中创建的表中

我已经使用sqlite db explorer打开了房间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

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

new PopulateDB(RoomDatabase.getDatabase(context), product);
您正在创建一个异步任务。您从未执行它,因此您的doInBackground没有运行。您可以通过在doInBackground中放置断点或向doInBackground添加日志来测试这一点

要修复它,请执行异步任务

另外,请注意,由于您没有使用onPostExecute,因此与使用任何其他线程解决方案Thread、Executor、RxJava等相比,在这里使用AsyncTask没有什么价值

您正在创建一个异步任务。您从未执行它,因此您的doInBackground没有运行。您可以通过在doInBackground中放置断点或向doInBackground添加日志来测试这一点

要修复它,请执行异步任务


另外,请注意,由于您没有使用onPostExecute,因此与使用任何其他线程解决方案Thread、Executor、RxJava等相比,在这里使用AsyncTask没有什么价值。

真不敢相信它是这么小的东西,我找错了地方。谢谢你真不敢相信它这么小,我找错地方了。非常感谢。