在本地数据库Room中插入对象列表

3
我有一个CidVo类:
@Entity
public class CidVo implements Serializable {

    private static final long serialVersionUID = 6128323407787450445L;

    @NonNull
    @PrimaryKey
    private String idCid;

    private String dsCid;
    //private StatusType idStatus;

    public CidVo() {
        super();
    }

    public String getIdCid() {
        return idCid;
    }

    public void setIdCid(String idCid) {
        this.idCid = idCid;
    }

    public String getDsCid() {
        return dsCid;
    }

    public void setDsCid(String dsCid) {
        this.dsCid = dsCid;
    }

    /*public StatusType getIdStatus() {
        return idStatus;
    }

    public void setIdStatus(StatusType idStatus) {
        this.idStatus = idStatus;
    } */

}

DAO类:

@Dao
public interface CIDDao {

    @Insert(onConflict = OnConflictStrategy.REPLACE)
    void insertAllCID(ArrayList<CidVo>... cidVos);
}

我通过JSON获取了一个对象列表,并希望将其保存到数据库中。但是,当我尝试编译时,会出现以下返回错误:

错误:实体类必须用@Entity进行注释 E:\workspace_android_studio\app_atendimento_branch_test\app\src\main\java\br\com\sisteplan\app\atendimento\Model\CIDDao.java 错误:(19, 43) 错误:参数的类型必须是使用@Entity进行注释的类或其集合/数组。

如何解决这个问题? 以下是postExecute:
 @Override
    protected void onPostExecute(AsyncTaskResult<Retorno> respAtestadoVo) {
        super.onPostExecute(respAtestadoVo);
        if (respAtestadoVo.getExceptionResult() == null) {
            RetornoCid retornoCid = (RetornoCid) respAtestadoVo.getResult();
            ArrayList<CidVo> cidVos = (ArrayList<CidVo>) retornoCid.getRetorno();

            appDataBase.getCidDao().insertAllCID(cidVos);

            Toast.makeText(context, "Sucesso", Toast.LENGTH_SHORT).show();
        }
    }

示例:

@Database(entities = {CidVo.class}, version = 1)
public abstract class AppDataBase extends RoomDatabase {
    public abstract CIDDao getCidDao();

    private static AppDataBase appDataBase;

    public static AppDataBase getInstance(Context context){
        if(null == appDataBase){
            appDataBase = buildDataBaseInstance(context);
        }
        return appDataBase;
    }

    private static AppDataBase buildDataBaseInstance(Context context){
        return Room.databaseBuilder(context,
                AppDataBase.class,
                "app_database")
                .allowMainThreadQueries().build();
    }

    private void cleanUp(){
        appDataBase = null;
    }

}
1个回答

2

这里使用了可变参数符号 void insertAllCID(ArrayList<CidVo>... cidVos); 你试图插入一个数组的ArrayList。 所以,只需将其替换为

void insertAllCID(List<CidVo> cidVos);

另外,在处理集合时,最好使用接口而不是具体实现。所以,您可以更改此部分。

RetornoCid retornoCid = (RetornoCid) respAtestadoVo.getResult();
ArrayList<CidVo> cidVos = (ArrayList<CidVo>) retornoCid.getRetorno();

转换成这样

RetornoCid retornoCid = (RetornoCid) respAtestadoVo.getResult();
List<CidVo> cidVos = new ArrayList(retornoCid.getRetorno());

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接