Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/212.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 从房间DAO接口继承_Android_Android Room - Fatal编程技术网

Android 从房间DAO接口继承

Android 从房间DAO接口继承,android,android-room,Android,Android Room,我有以下接口,在这里我创建了标准的crud方法,并用insert、update和delete注释了这些方法 interface BaseDao<T> { @Insert fun insert(table: T): Single<Long> @Insert fun insert(vararg table: T): Single<List<Long>> @Update fun update(table

我有以下接口,在这里我创建了标准的crud方法,并用insert、update和delete注释了这些方法

interface BaseDao<T> {
    @Insert
    fun insert(table: T): Single<Long>

    @Insert
    fun insert(vararg table: T): Single<List<Long>>

    @Update
    fun update(table: T): Single<Int>

    @Delete
    fun delete(table: T): Single<Int>
}
然后,我为DAO创建一个接口

@Dao
interface WeatherDao : BaseDao<WeatherTable> {

    override fun insert(table: WeatherTable): Single<Long>

    override fun insert(vararg table: WeatherTable): Single<List<Long>>

    override fun update(table: WeatherTable): Single<Int>

    override fun delete(table: WeatherTable): Single<Int>

    @Query("SELECT * FROM weatherTable")
    fun getAllWeather(): Single<List<WeatherTable>>

    @Query("SELECT * FROM weatherTable WHERE id = :id LIMIT 1")
    fun getWeatherById(id: Long): Single<WeatherTable>

    @Query("SELECT count(*) FROM weatherTable")
    fun count(): Single<Int>
}
当我编译时,会出现如下错误:

error: An abstract DAO method must be annotated with one and only one of the following annotations: Insert,Delete,Query,Update,RawQuery
    public abstract io.reactivex.Single<java.lang.Long> delete(@org.jetbrains.annotations.NotNull()
因为当我从接口继承时。我必须手动添加@Insert、@Update和@Delete

只是想知道为什么这些注释会自动添加到MyWeatherDao界面中

因此,我现在必须手动添加它们,如下所示:

@Dao
interface WeatherDao : BaseDao<WeatherTable> {

    @Insert
    override fun insert(table: WeatherTable): Single<Long>

    @Insert
    override fun insert(vararg table: WeatherTable): Single<List<Long>>

    @Update
    override fun update(table: WeatherTable): Single<Int>

    @Delete
    override fun delete(table: WeatherTable): Single<Int>

    @Query("SELECT * FROM weatherTable")
    fun getAllWeather(): Single<List<WeatherTable>>

    @Query("SELECT * FROM weatherTable WHERE id = :id LIMIT 1")
    fun getWeatherById(id: Long): Single<WeatherTable>

    @Query("SELECT count(*) FROM weatherTable")
    fun count(): Single<Int>
}
只是想知道我是否用错了:

接下来,你没有正确地进行抽象。总之,您不需要在@Dao接口中插入/更新/删除,它应该是抽象的

interface BaseDao<T> {

    /**
     * Insert an object in the database.
     *
     * @param obj the object to be inserted.
     */
    @Insert
    fun insert(obj: T)

    /**
     * Insert an array of objects in the database.
     *
     * @param obj the objects to be inserted.
     */
    @Insert
    fun insert(vararg obj: T)

    /**
     * Update an object from the database.
     *
     * @param obj the object to be updated
     */
    @Update
    fun update(obj: T)

    /**
     * Delete an object from the database
     *
     * @param obj the object to be deleted
     */
    @Delete
    fun delete(obj: T)
}

为什么在WeatherDao中重写BaseDao的crud方法?通过移除它们,它应该得到解决!
@Entity(tableName = "data")
data class Data(@PrimaryKey val id: String, val value: String)
@Dao
abstract class DataDao : BaseDao<Data>() {

    /**
     * Get all data from the Data table.
     */
    @Query("SELECT * FROM Data")
    abstract fun getData(): List<Data>
}