Spring Boot中使用mongo的复杂查询查找实体中List「T」中的某个属性

Spring Boot中使用mongo的复杂查询查找实体中List中的某个属性

在Spring Boot中使用mongodb数据库来进行增删改查操作,一般在Dao层使用MongoRepository来进行一些基础的增删改查,也可以自己根据MongoRepository提供的方法来写一些需要的增删改查操作。例如findFirstById、findByClassificationsIn、findAllByAuthor等。
但是如果需要判断的条件位于查找实体的List字段中,例如:

public class DataItem extends Item{
    List<RelatedProcessing> relatedProcessings;
    List<RelatedVisualization> relatedVisualizations;
  }
@Document
@Data
public class RelatedProcessing {
    String proId;
    String proName;
    String proDescription;
    String token;
    String xml;
}

在这个数据结构中,如何根据RelatedProcessing 字段中的proId来定位DataItem呢?这时候就需要引入MongoTemplate来进行较为复杂的查询
在这个过程中将使用Criteria。
Criteria对SQL进行封装,可以让开发人员可以用对象的方式对数据库进行操作。
以下为具体的示例

//首先引入MongoTemplate
@Autowired
private MongoTemplate mongoTemplate;

//初始化Criteria
org.springframework.data.mongodb.core.query.Criteria criteria = org.springframework.data.mongodb.core.query.Criteria.where("relatedProcessings").elemMatch(Criteria.where("proId").is(pcsId));
//使用query
Query query = new Query(criteria);
//匹配DataItem
List<DataItem> dataItems = mongoTemplate.find(query,DataItem.class);

以上代码等同于mongodb数据库操作:

db.dataItem.find({relatedProcessings:{$elemMatch:{proId:"b8faefaa-83ad-4ec7-a282-7b59757a60d6"}}})

通过这些操作,即可匹配到id为pcsId的所有DataItem

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值