【问题标题】:"WHERE IN" statement using greendao Android ORM使用greendao Android ORM的“WHERE IN”语句
【发布时间】:2016-04-05 23:32:26
【问题描述】:

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

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

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

【问题讨论】:

标签: android sqlite orm greendao


【解决方案1】:

您可以使用 Guava 中的Lists.transform(),如此处所述link

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

【讨论】:

    猜你喜欢
    • 2012-12-24
    • 1970-01-01
    • 2016-11-26
    • 2015-03-22
    • 2016-05-13
    • 1970-01-01
    • 2013-10-16
    • 2010-12-23
    相关资源
    最近更新 更多