"WHERE IN"使用绿道安卓ORM的声明



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

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

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

您可以使用Guava中的Lists.transform()链接

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();

相关内容

  • 没有找到相关文章

最新更新