繁体   English   中英

如何在android中将数据从房间表插入到另一个房间?

[英]How insert data from a room table to another in android?

我有一个从 api 获取数据的应用程序,然后将其保存到 RoomDatabase(RoomTable)。

我在主屏幕中使用 recyclerview 显示这些数据。

正如我所说我的产品在数据库中的模型房间表中(RoomTable 是该表的名称),那么在这种情况下如何将我的产品插入到房间数据库中的另一个表(CartTAable)中每个产品的添加按钮之后被点击了吗?

我希望可以清楚地描述这一点。 谢谢你 。

表:

@entity
class RoomTable (
  
  @primarykey
  autoincrement = true
  val id : Int 
  val title : String 


@entity
  class CartTAble (
  
  @primarykey
  autoincrement = true
  val id : Int 
  val title : String 

)


@Insert(replace strategy)
fun insertToCart(model : List<CartTable)


我也有存储库和视图模型,但为简单起见忽略。

adapter : 

class Myadapter (myproduct : List<RoomTAble> ) : Recycerlview.Adapter<Myadapter.Viewholder>(){

 val viewmodel : Viewmodelroom()

class Viewholder (view : View ) : RecyclerView.ViewHolder(){

    val title =  view.findviewbyid(R.id.sometihng)
    val image = view.finviewbyid(R.id.Someimage)

}

  override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {


        val layoutview =
            LayoutInflater.from(parent.context).inflate(R.layout.product_items, parent, false)
        return ViewHolder(layoutview)

    }


 override fun getItemCount(): Int = myproduct.size


override fun onBindViewHolder(holder: ViewHolder, position: Int) {


        val products = myproduct[position]


        holder.title.text = products.title
        Picasso.get().load(products.image).into(holder.imageproduct)


        holder.btn_add_product.setOnClickListener {

            viewModel.insertToCart()

   // in here for insertTocart paramter it need list<CArtTAble> but we have just list of RoomTAble
        }

首先,您的命名约定是错误的。 RoomTable 和 CartTable 是笔记表,它们是模型或实体。

第二。 只需使用 RoomTable 中的数据创建 CartTable。

val modelCart = CartTable(title = products.title)

您也可以只插入 1 个模型。 只需添加。

@Insert(replace strategy)
fun insertCart(model: CartTable)

然后只需将其保存到数据库中。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM