MongoTemplate 操作 Mongo的字段中List元素

文章展示了在MongoDB中对文档的subscribers字段进行操作的方法,包括添加新数据、删除数据和编辑数据。使用Java的MongoTemplate进行查询和更新,基于_id和subscribers.userId进行精准定位。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mongo中原始数据

{
	"_id": {
		"$numberLong": "7085200805669904384"
	},
	"message": "Thank you for your support",
	"announcement": "weekend",
	"created_user_id": {
		"$numberLong": "8637022162191"
	},
	"update_time": {
		"$date": "2022-12-15T06:24:00.193Z"
	},
	"status": "1",
	"subscribers": [
		{
			"boolean": false,
			"userId": {
				"$numberLong": "8637022162191"
			}
		}
	]
}

给subscribers 字段新增一条数据

    public static void main(String[] args) {
        Query query = new Query();
        query.addCriteria(Criteria.where("_id").is(7085200805669904384L));
        Update update = new Update();
       
        Map<String, Object> sub = new HashMap<>();
        sub.put("userId", 8637022162191L);
        sub.put("boolean", false);
        update.push("subscribers", sub);
        mongoTemplate.updateFirst(query, update, "store_time_away");
    }

给subscribers 字段删除一条数据

    public static void main(String[] args) {
        Query query = new Query();
        query.addCriteria(Criteria.where("_id").is(7085200805669904384L));
        Update update = new Update();
     
        Map<String, Object> sub = new HashMap<>();
        sub.put("userId", 8637022162191L);
        update.pull("subscribers", sub);
        mongoTemplate.updateFirst(query, update, "store_time_away");
    }

给subscribers 编辑一条数据

    public static void main(String[] args) {
        Query query = new Query();
        query.addCriteria(Criteria.where("_id").is(7085200805669904384L))
                .addCriteria(Criteria.where("subscribers.userId").is(8637022162191L));
        Update update = new Update();
       //不预先查询文档我们就不知道要修改数组的元素的下标。这时定位操作符“$”
        update.set("subscribers.$.boolean",false);
        mongoTemplate.updateFirst(query, update, "store_time_away");
    }

查询

   public static void main(String[] args) {
        Query query = new Query();
        query.addCriteria(Criteria.where("_id").is(7085200805669904384L))
                .addCriteria(Criteria.where("subscribers.userId").is(8637022162191L));

        StoreTimeAwayV1 storeTimeAways = mongoTemplate.findOne(query,  StoreTimeAwayV1.class);
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值