首页 > 数据库 > 其他综合 >

MongoDB修改、删除文档的域属性实例

2015-07-16

MongoDB修改、删除文档的域属性实例 在网站的开发中,可能最初的设计不合理,或者后期业务的变更,会造成文档结构会有些没用的属性,需要去删除或修改,由于MongoDB 是无 Schema 的,不像关系数据库那样

MongoDB修改、删除文档的域属性实例

在网站的开发中,可能最初的设计不合理,或者后期业务的变更,会造成文档结构会有些没用的属性,需要去删除或修改,由于MongoDB 是无 Schema 的,不像关系数据库那样列属性定义在表而非记录中,MongoDB 的集合中的每个文档可以拥有各自不同的域属性。MongoDB 中使用 db.collections.update 修改集合中若干文档的域属性,使用 $set 增加域,$unset 删除域。
删除集合中所有文档的一个域

db.posts.update({}, { $unset: { deleted_at: 1 } }, { multi: true })


1.第一个参数表示选中某些文档,这里为 {} 表示选中当前 posts 集合中的所有文档

2.第二个参数为具体的更新操作,$unset 表示删除域

3.第三个参数为额外选项,{ multi: true } 表示更新所有满足要求的文档,默认只会更新第一个

也可以同时删除多个域

db.categories.update({}, { $unset: { deleted_at: 1, desc: 1 } }, { multi: true })


也以同时删除和新增域

db.tags.update(

    {},

    { $unset: { deleted_at: 1 }, $set: { slug: 1, description: 1 } },

    { multi: true }

)
相关文章
最新文章
热点推荐