如何解决如何在 Spring MongoDB 中删除数组中的嵌套对象
我有一个使用 MongoDB 的 Spring 项目。我没有域类,因为我的项目以通用方式处理数据。 我正在尝试删除数组中的一些对象,但我不能。我已经搜索过 StackOverflow,但找到的信息并没有帮助我解决这个问题。以下是我收藏中的文档的总结示例:
{ _id
dispositivos:[
{ uid },{ uid }
}
我尝试仅删除具有我在 id 列表中传递的 id 的对象。 这是我迄今为止尝试过的方法,但不起作用。
public UpdateResult deleteDispositivosByIds(String idCentro,List<String> ids) {
// NOT WORKING--------
// ObjectId objectId = new ObjectId(idCentro);
// Query query = new Query();
// query.addCriteria(Criteria.where("_id").is(objectId));
// Update update = new Update();
// BasicDBObject[] boArray = new BasicDBObject[ids.size()];
// String[] idsArray = new String[ids.size()];
// idsArray=ids.toArray(idsArray);
// for (int i = 0; i < boArray.length; i++) {
// boArray[i]=new BasicDBObject("uid",idsArray[i]);
// System.out.println(idsArray[i]);
// }
// update.pullAll("dispositivos",boArray );
// mongoTemplate.updateFirst(query,update,"centros");
// return null;
// NOT WORKING--------
// ObjectId objectId = new ObjectId(idCentro);
// Query query = new Query();
// query.addCriteria(Criteria.where("_id").is(objectId));
// Update update = new Update();
// update.pullAll("dispositivos",ids.toArray() );
// mongoTemplate.updateFirst(query,"centros");
// return null;
// NOT WORKING--------
ObjectId objectId = new ObjectId(idCentro);
Query query = new Query();
query.addCriteria(Criteria.where("_id").is(objectId));
query.addCriteria(Criteria.where("dispositivos.uid").in(ids));
Update update = new Update();
update.pull("dispositivos",query );
mongoTemplate.updateFirst(new Query(),"centros");
return null;
}
解决方法
那是我的解决方案(“centros”是集合名称):
public UpdateResult deleteDispositivosByIds(String idCentro,List<String> ids) {
ObjectId objectId = new ObjectId(idCentro);
Query query = new Query();
query.addCriteria(Criteria.where("_id").is(objectId));
Update update = new Update();
update.pull("dispositivos",new Query(Criteria.where("uid").in(ids)) );
return mongoTemplate.updateFirst(query,update,"centros");
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。