我有以下课程:
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;
}
但是,如果我只想获取给定的查询topic
(channelType
可以是任何东西)怎么办?我们如何为此创建查询?
一种选择是使用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;
}