繁体   English   中英

Room @Query错误:无法找到方法参数

[英]Room @Query error: Cannot find method parameters

在我的项目中,我有一个库模块和一个使用它的应用程序模块。 在这两个模块中,我对Android架构组件库具有相同的gradle依赖关系:

// ViewModel and LiveData
implementation "android.arch.lifecycle:extensions:1.0.0"
implementation "android.arch.lifecycle:common-java8:1.0.0"

// Room
implementation "android.arch.persistence.room:runtime:1.0.0"
annotationProcessor "android.arch.persistence.room:compiler:1.0.0"

在我的库模块中,我定义了一个User实体

@Entity(tableName = "users",
    indices = {@Index(value = {"firstName", "lastName"})})
public class User {

public enum ROLE {
    ...
}

public enum FEEDBACK_LEVEL {
    ...
}

@PrimaryKey
public int id;

@TypeConverters(UserConverters.class)
ROLE role;

@TypeConverters(UserConverters.class)
FEEDBACK_LEVEL feedbackLevel;

public String firstName;

public String lastName;


public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public ROLE getRole() {
    return role;
}

public void setRole(ROLE role) {
    this.role = role;
}

public FEEDBACK_LEVEL getFeedbackLevel() {
    return feedbackLevel;
}

public void setFeedbackLevel(FEEDBACK_LEVEL feedbackLevel) {
    this.feedbackLevel = feedbackLevel;
}

public String getFirstName() {
    return firstName;
}

public void setFirstName(String firstName) {
    this.firstName = firstName;
}

public String getLastName() {
    return lastName;
}

public void setLastName(String lastName) {
    this.lastName = lastName;
}
}

和相关的DAO接口

@Dao
public interface UserDAO {
    @Insert(onConflict = OnConflictStrategy.REPLACE)
    void insertUser(User ... u);

    @Query("select * from users where users.id = :userId")
    LiveData<User> getUser(int userId);
}

在我的应用程序模块中,我创建了我的数据库,其中我正在使用库项目中定义的实体

@Database(entities = {User.class}, version = 1)
public abstract class TDatabase extends RoomDatabase{
    private static TDatabase sInstance;

    public static TDatabase getInstance(final Context c) {
        if(sInstance == null)
            sInstance = Room.databaseBuilder(c, TDatabase.class, "t_db").build();
        return sInstance;
    }

    public abstract UserDAO userDao();
}

问题是,当我尝试使用其名称@Query语句中的方法参数时,我得到以下错误

错误:查询中的每个绑定变量都必须具有匹配的方法参数。 无法找到以下方法参数:userId。

如果我改变@Query

@Query("select * from users where users.id = :userId")
LiveData<User> getUser(int userId);

@Query("select * from users where users.id = :arg0")
LiveData<User> getUser(int userId);

一切正常。

我在做错吗? 为什么我收到此错误? 我用谷歌搜索了一个解决方案,但我发现在使用Java时只有Kotlin的结果。

此问题在https://issuetracker.google.com/issues/68118746上报告并在版本1.1.0-alpha3中修复,但仅适用于Kotlin代码,因为参数名称始终存储在Kotlin类元数据中。

对于Java,只有使用:arg0解决方法,直到将NamedArg之类的注释添加到Room。

我认为你应该这样使用它:

@Query("select * from users where id = (:userId)")
LiveData<User> getUser(int userId);

暂无
暂无

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

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