微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

卡在数据库机房中进行插入和更新

如何解决卡在数据库机房中进行插入和更新

我希望可以清楚地描述我的问题。

我想在数据库室中插入一些值。实际上,我希望在将新值发送到具有旧值的数据库sum时不替换它。

为此,我为dao编写了一些方法(插入,更新和获取所有数据)。

但是问题是我无法编写正确的if语句来说,当有旧值时,调用更新方法,新值与旧值相加,并且数据库中没有值,因此插入方法称为。 '

代码

我的桌子:

@Entity (tableName = "credit")
data class Credit(

    @PrimaryKey(autoGenerate = true)
    val id : Int?,var credittext: Long)

我的道:

@Query("SELECT * FROM credit ")
    fun creditall(): LiveData<Credit>

@Insert(onConflict = OnConflictStrategy.REPLACE)
    suspend fun insertcredit(model: Credit)

 @Query("UPDATE credit SET credittext = credittext + :value WHERE id = :id")
    suspend fun updateSum(id: Int?,value: Long)

 @Query("SELECT * FROM credit WHERE id = :id")
    suspend fun getCreditById(id: Int?): Credit

我的存储库:

 fun getallcredit() = db.GetDao().creditall()

 suspend fun insertcredit(model : Credit) = db.GetDao().insertcredit(model)

 suspend fun update (id : Int?,value : Long)= db.GetDao().updateSum(id,value)

我的viewmodel:

 fun creditall() = repository.getallcredit()

    fun insertcredit(model: Credit) = Coroutinescope(dispatchers.IO).launch {


        repository.insertcredit(model)


    }

  fun updatecredit(id : Int?,value : Long) = Coroutinescope(dispatchers.IO).launch {


        repository.update(id,value)

    }

活动:


  private fun paymentVerification() {


        val data: Uri? = intent.data

        val getpurchase = ZarinPal.getPurchase(this)


        getpurchase.verificationPayment(data) {

                isPaymentSuccess,refID,paymentRequest ->

            if (isPaymentSuccess) {

     // this is where i can't figure it out how do it .
            val id : Int ?= null

                if (viewmodel.getCreditById(id) != viewmodel.getCreditById(null)) {

                    viewmodel.updatecredit(1,paymentRequest.amount)

                }else {
                    viewmodel.insertcredit(Credit(1,paymentRequest.amount))
                }



                Toast.makeText(this,"افزایش موجودی شما انجام شد",Toast.LENGTH_LONG).show()




            } else {

                Toast.makeText(
                    this,"در عملیات پرداخت خطایی رخ داده ، لطفا دوباره سعی کنید",Toast.LENGTH_LONG
                ).show()


            }

任何帮助将不胜感激。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。