首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >执行带有房间和@数据库注释的org.jetbrains.kotlin.gradle.internal.KaptExecution时出错

执行带有房间和@数据库注释的org.jetbrains.kotlin.gradle.internal.KaptExecution时出错
EN

Stack Overflow用户
提问于 2020-07-02 15:24:00
回答 5查看 3.5K关注 0票数 7

我正在使用Room进行离线存储。我的模型包含了Room不支持的列表,我编写了类型转换器,但现在我得到了这个错误。当我删除@Database注解时,错误就会出现,但是使用@Database注解时,会显示错误。这是我所有相关的类。

这是我的刀

代码语言:javascript
运行
复制
package com.example.mvvm.room

import androidx.lifecycle.MutableLiveData
import androidx.room.Dao
import androidx.room.Delete
import androidx.room.Insert
import androidx.room.Query
import com.example.mvvm.models.Result

@Dao
interface MovieDao {
    @Query("Select * from Result")
    fun readMovieList():MutableLiveData<ArrayList<Result>>

    @Insert
    fun insertData(result: Result)

    @Delete
    fun deleteAll()
}

这是我的Database类

代码语言:javascript
运行
复制
package com.example.mvvm.room
import android.content.Context
import androidx.room.*
import com.example.mvvm.MyTypeConverter
import com.example.mvvm.models.Result

@Database(entities = arrayOf(Result::class),version = 1)
@TypeConverters(MyTypeConverter::class)
abstract class MovieDatabase:RoomDatabase(){
   companion object{

      private var INSTANCE:MovieDatabase?=null
      fun getInstance(context: Context):MovieDatabase? {
         if (INSTANCE == null) {
            synchronized(MovieDatabase::class) {
               INSTANCE = Room.databaseBuilder(context, MovieDatabase::class.java, "movie.db").
               fallbackToDestructiveMigration()
                  .allowMainThreadQueries()
                  .build()
            }
         }
         return INSTANCE
      }
   }
   abstract fun movieDao():MovieDao
}

这是我的模型

代码语言:javascript
运行
复制
package com.example.mvvm.models

import androidx.room.ColumnInfo
import androidx.room.Entity
import androidx.room.TypeConverters
import com.example.mvvm.MyTypeConverter

@Entity(tableName = "result")
data class Result(
    @ColumnInfo val adult: Boolean,
    @ColumnInfo val backdrop_path: String,
    @TypeConverters(MyTypeConverter::class)
    @ColumnInfo val genre_ids: List<Int>,
    @ColumnInfo val id: Int,
    @ColumnInfo val original_language: String,
    @ColumnInfo val original_title: String,
    @ColumnInfo val overview: String,
    @ColumnInfo val popularity: Double,
    @ColumnInfo val poster_path: String,
    @ColumnInfo val release_date: String,
    @ColumnInfo val title: String,
    @ColumnInfo val video: Boolean,
    @ColumnInfo val vote_average: Double,
    @ColumnInfo val vote_count: Int
)

类型转换器类

代码语言:javascript
运行
复制
package com.example.mvvm

import androidx.room.TypeConverter
import com.google.gson.Gson
import com.google.gson.reflect.TypeToken

class MyTypeConverter {

    companion object{
        private val gson = Gson()
        @JvmStatic
        @TypeConverter
        fun toJson(mInt : List<Int>):String{
            return gson.toJson(mInt)
        }

        @JvmStatic
        @TypeConverter
        fun fromJson(string : String):String{
            val type = object : TypeToken<List<Int>>(){}.type
            return gson.fromJson(string, type)
        }
    }
}

下面是错误

代码语言:javascript
运行
复制
A failure occurred while executing org.jetbrains.kotlin.gradle.internal.KaptExecution
EN

回答 5

Stack Overflow用户

发布于 2020-07-04 19:12:26

您可以在调试模式下进行编译,以获取有关错误的更多详细信息,并找到问题所在。

去android Gradle菜单/ Other / compileDebugKotlin (android studio的右边栏)你应该有关于这个错误的更多细节,然后你可以在这里发布它以获得更多帮助。

票数 7
EN

Stack Overflow用户

发布于 2020-07-02 15:31:22

我认为问题出在你在@Query("Select * from Result")MovieDao

应该是@Query("Select * from result")

票数 1
EN

Stack Overflow用户

发布于 2020-07-04 19:25:47

我通过在MovieDao readMovieList中将MutableLiveData改为LiveData并将delete注解改为查询(从结果中删除)解决了这个问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62691082

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档