客观化过滤空值

时间:2012-11-26 15:23:00

标签: google-app-engine google-cloud-datastore objectify

如何使用Objectify 4通过几个参数正确过滤,考虑到其中一些参数可能为空,这意味着我不想按这些参数进行过滤? 例: 请考虑我想过滤这样的事情:

      releases = ofy().load().type(Release.class)
                .filter("user.name", searchCriteria.getName())
                .filter("category", searchCriteria.getCategory())
                .filter("city", searchCriteria.getCity()).list();

为了与我上面说的相匹配,我现在有以下代码,每次检查哪些参数都是空的,所以在这种情况下我不会将它们放在过滤器上:

    if (!nameEmpty && !categoryEmpty && !cityEmpty) {
        releases = ofy().load().type(Release.class)
                .filter("user.name", searchCriteria.getName())
                .filter("category", searchCriteria.getCategory())
                .filter("city", searchCriteria.getCity()).list();
    } else if (!nameEmpty && !categoryEmpty) {
        releases = ofy().load().type(Release.class)
                .filter("user.name", searchCriteria.getName())
                .filter("category", searchCriteria.getCategory()).list();
    } else if (!nameEmpty && !cityEmpty) {
        releases = ofy().load().type(Release.class)
                .filter("user.name", searchCriteria.getName())
                .filter("city", searchCriteria.getCity()).list();
    } else if ...

       ...

如何使用Objectify 4避免使用这种糟糕的过滤方式并使用一行(或几行)进行过滤?

1 个答案:

答案 0 :(得分:5)

Query<Release> query = ofy().load().type(Release.class);

if (!nameEmpty)
    query = query.filter("user.name", searchCriteria.getName());

if (!categoryEmpty)
    query = query.filter("category", searchCriteria.getCategory())

if (!cityEmpty)
    query = query.filter("city", searchCriteria.getCity());

releases = query.list();