使用greendao Android ORM的“WHERE IN”语句

使用greendao Android ORM的“WHERE IN”语句,android,sqlite,orm,greendao,Android,Sqlite,Orm,Greendao,我正在使用greendao在我的应用程序中处理sqlite数据库。 我需要有这样的功能,如在哪里的条件 我正在寻找这样的方法或任何其他可能的方法,但不使用原始查询 我需要在SELECT id FROM company WHERE state=1中执行这样的查询SELECT*FROM news WHERE id_company 请建议使用GreenDAO ORM执行此类查询的最佳方式。您可以使用此处描述的Guava 以下是官方文档中的解决方案: List<Company> compan

我正在使用greendao在我的应用程序中处理sqlite数据库。 我需要有这样的功能,如在哪里的条件 我正在寻找这样的方法或任何其他可能的方法,但不使用原始查询

我需要在SELECT id FROM company WHERE state=1中执行这样的查询SELECT*FROM news WHERE id_company

请建议使用GreenDAO ORM执行此类查询的最佳方式。

您可以使用此处描述的Guava


以下是官方文档中的解决方案:
List<Company> companies = session.getCompanyDao()
                           .queryBuilder()
                           .where(CompanyDao.properties.state.eq(1))
                           .list();

Function<Company, Integer> companyToId = new Function<Company,Integer>() { 
    public String apply(Company c) { return c.getId(); }
};

List<Integer> ids = Lists.transform(companies, compnayToId);


session.getNewsDao()
.queryBuilder()
.where(NewsDao.Properties.id_company.in(ids))
.list();