1

我有以下课程:

class Document{
    Map<EnumChannelType, Channel> data;
    //some more fields
}
class Channel{
    String topic;
    //some more fields
}

enum EnumChannelType{
    BASIC_CHANNEL(1), ADVANCED_CHANNEL(2),......;
    int value;
    //constructor and some methods
}

现在我想在topic里面查询Channel。如果channelType已知,我们可以很容易地查询如下:

Query<Document> createQuery(EnumChannelType channelType, String topic){
    Query<Document> query = dao.createQuery().disableValidation();
    query.field("data." + channelType.name() + ".topic").equal(topic);
    return query;
}

但是,如果我只想获取给定的查询topicchannelType可以是任何东西)怎么办?我们如何为此创建查询?

一种选择是使用or如下:

Query<Document> createQueryForTopic(String topic) {
    Query<Document> query = dao.createQuery().disableValidation();
    // add all possible Channel Types
    query.or(query.criteria("data." + EnumChannelType.BASIC_CHANNEL.name() + ".topic").equal(topic),
            query.criteria("data." + EnumChannelType.ADVANCED_CHANNEL.name() + ".topic").equal(topic),
            /*...add criteria for all possible channel types*/);
    return query;
}

EnumChannelType但是,如果随着时间的推移而变化或EnumChannelType有大量成员(如BASIC_CHANNEL(1), ADVANCED_CHANNEL(2),....) ,这是不可行的。

我正在寻找类似...

Query<Document> createQuery(String topic){
    Query<Document> query = dao.createQuery().disableValidation();
    // use some regex instead of ????
    query.field("data." + ???? + ".topic").equal(topic);
    return query;
}
4

1 回答 1

1

我几乎可以肯定 Morphia 和 MongoDB 不支持字段名称的正则表达式。在这种情况下,最好的选择是使用$or运算符。您可以遍历整个枚举以避免错误:

List<Criteria> criterias = new ArrayList<Criteria>();
for(EnumChannelType v : EnumChannelType.values()) {
    criterias.add(query.criteria("data." + v.name() + ".topic").equal(topic));
}

query.or(criterias.toArray(new Criteria[criterias.size()]);

请记住,$or运算符并行执行查询,然后合并结果。

信息:http ://docs.mongodb.org/manual/reference/operator/or/#op._S_or

于 2013-07-05T13:32:46.617 回答