对应的sql
-- 删除某个字段,也可以在第一个大括号中带条件
db.collection.updateMany({},{$unset:{sequence:''}},false,true)
-- 根据条件增加字段,不带条件就是全表添加字段
db.collection.updateMany({type:'VIDEO_UNIT'}, {$set: { sequence: 'null'}})
-- 根据条件,修改某个字段的数据类型
db.wx_center_resource_live_room.find({"liveStartTime":{$type:2}}).forEach(function(x){x.liveStartTime=Date(x.status);db.wx_center_resource_live_room.save(x)})
-- 模糊匹配的语句$regex
db.getCollection("wx_center_resource_question").find({"vignette.content" : {$regex:"测试"}})
或者
db.wx_center_resource_question.aggregate([{"$match": {"tenantId": 1, "vignette.content": {$regex:"测试"}}}]);
-- MongoTemplate 模糊匹配的写法
if (StringUtils.hasText(content)) {
c.and("vignette.type").is(3);
//c.and("vignette.content").regex(".*?" + content.trim() + ".*", "i");
//经过测试这种和上一行效果是一样的
c.and("vignette.content")
.regex(content.trim());
}
或者
if (StringUtils.hasText(name)) {
//模糊查询 正则name是你需要输入的查询值
Pattern pattern =
Pattern.compile("^.*" + name + ".*$", Pattern.CASE_INSENSITIVE);
r.and("name").regex(pattern);
}
update/updateMany命令格式:
db.collection.update(criteria,objNew,upsert,multi)
参数说明:
criteria:查询条件
objNew:update对象和一些更新操作符
upsert:如果不存在update的记录,是否插入objNew这个新的文档,true为插入,默认为false,不插入。
multi:默认是false,只更新找到的第一条记录。如果为true,把按条件查询出来的记录全部更新。
数据类型参考表

博客介绍了MongoDB与SQL的对应情况,重点讲解了update/updateMany命令格式。包括参数说明,如查询条件、update对象及操作符,还提及upsert决定是否插入新文档,multi决定更新记录数量,同时给出了数据类型参考表。
1360

被折叠的 条评论
为什么被折叠?



