MongoDB 的增、查、改、删

这篇具有很好参考价值的文章主要介绍了MongoDB 的增、查、改、删。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Monogo使用

  1. 单条增加
db.member.insertOne({"name":"张三","age":18,"create":new Date()})
db.member.insert({"name":"李四1","age":18,"create":new Date()})
db.member.insertOne({"_id":1,"name":"张三","age":18,"create":new Date()})
  1. 多条增加
db.member.insertMany([{"_id":2,"name":"李四","age":18,"create":new Date()},{"_id":3,"name":"王五","age":18,"create":new Date()}])

查询

这个查询,每一块都是一个个复杂的json串组合而成

  1. 查询age=18
# 缩写
db.member.find({age:18});
# 完整写法
db.member.find({
    age: {
        $eq: 18
    }
});
  • 查询 _id>2 并且 age =18
# 缩写
db.member.find({_id :{$gt: 2}, age:18});
# 完整写法
db.member.find({
    $and: [
    {
        _id: {
            $gt: 2
        }
    }, 
    {
        age: {
            $eq: 18
        }
    }]
})
  1. 排序
  • -1 是降序
  • 1 是升序
db.member.find({_id :{$gt: 2}}).sort({_id:-1});
  1. 分页
  • skip:跳过指定记录数
  • limit:返回结果数量
# 跳过第一条后,返回3条数据
db.member.find().skip(1).limit(5);
#假如有数据1,2,3,4,5
#返回 2,3,4
  1. 返回指定字段
  • 0代表不显示
  • 1代表显示
    ** 注意:_id默认是显示的,只有_id不显示是设置0,其他字段都不可以设置0 **

格式:find({查询条件,可以空},{显示的字段:1})

db.member.find({},{age:1})
  1. 查询操作符
操作符 格式 与mysql对比
$eq 等值比较,find({_id :{ $eq: 1}}) 等价于 find({_id : 1}) id = 1
$ne 不等于指定值,find({_id :{ $ne: 1}}) id != 1 或 id<> 1
$in 数组中包含 ,find( { _id :{ $in: [ 1,2 ] } } ) id in ( 1,2 )
$nin 数组中不包含,find( { _id :{ $nin: [ 1,2 ] } } ) id not in ( 1,2 )
$gt 大于指定值,find({_id :{$gt: 1}}) id > 1
$get 大于等于指定值,find({_id :{$gte: 1}}) id >= 1
$lt 小于指定值,find({_id :{$lt: 1}}) id < 1
$lte 小于等于指定值,find({_id :{$lte: 1}}) id <= 1
$and 与(并且)查询,find({$and:[ { _id:{ $gt:1} },{ _id:{ $lt:4} } ]}) id > 1 and id < 4
$or 或查询,find({$or:[ { _id:1 },{ _id: 3} ]}) id = 1 or id= 3
$not 非查询,非小于3的数据 find({_id :{$not :{ $lt: 3 } } }) id >= 3
$nor 即非查询,find( { $nor: [ { _id: 1 }, { _id: 2 }, { _id: 3 }] } ) (id != 1 and id !=2 and id !=3)
$all 同时包含,查询tag同时包含3和9的数据,tag是一个数组,find({tag:{$all:[3,9]}})
$elemMatch 有一个元素匹配即可,find({job:{$elemMatch:{city:‘beijing’,company:‘xiaomi’}}})
$size 匹配数组大小,find({tag:{$size:3}})
$slice 返回数组中第几个元素,find({job:{KaTeX parse error: Expected ‘EOF’, got ‘}’ at position 43: …ompany:‘baidu’}}̲},{name:1,job:{slice:1}})
$exists 匹配是否包含查询字段的文档,find({name:{$exists:true}})

修改

格式 : db.集合.update(query, update, options)

  • query:更新的查询条件
  • update:要更新的内容
  • options:更新的选项
  1. 更新单个文档
    更新_id等于3的年龄
db.member.update({_id:3},{$set:{age:11}})
db.member.updateOne({_id:3},{$set:{age:11}})
  1. multi更新多个文档
    **更新多个文档需要设置multi选项 :true,默认情况下mongo update命令在更新第一个文档后就返回。 **
db.member.update({age:19},{$set:{ name:‘zhang1’}},{‘multi’:true});
#要不你换成这样子写,就可以更新多条
db.member.updateMany({age:19},{$set:{ name:‘zhang33’}})
  1. upsert更新的字段不存在则插入
    ** upsert选项为true:如果更新文档不存在则创建文档,如果文档存在字段不存在则创建字段,都存在则更新**
db.member.update({_id:3}, { $set:{ address :‘北京’} } ,{upsert:true})
  1. indAndModify查询和修改
    ** 查询并修改指定值,注意先返回结果,后更新,返回的结果是旧数据 **
db.member.findAndModify({query:{name:‘张1’} , update:{ $set:{ ‘age’:18 } } })
  1. 查询并修改指定值,并返回新值
db.member.findAndModify({query:{name:‘张1’} , update:{ $set:{ ‘age’:18 } } })
操作符 格式 描述
$set { $set : { filed : value} } 指定一个键,并更新值
$unset { $unset : { filed : 1} } 删除一个键
$inc { $inc : { filed : value} } 对数值类型进行增减
$push { $push : { filed : value} } 将数值追加到数组中,若数组不存在则会进行初始化
$pushAll { $pushAll : { filed : value_array} } 追加多个值到数组内
$pull { $pull : { filed : value} } 从数组中删除指定元素
$addToSet { $addToSet : { filed : value} } 添加元素到数组中,具有排重功能
$pop { $pop : { filed : 1} } 删除数组第一个或最后一个
$rename { $rename : { old_filed_name : new_filed_name } } 修改地段名称
$bit { $bit : { filed : {and :5} } } 位操作,integer类型

删除

  1. 删除单个文档
db.member.deleteOne({_id:2})
  1. remove命令会删除匹配条件的全部文档,删除单个文档,可以根据_id 或者唯一值删除。
db.member.remove({name:‘张1’})
  1. 如果希望明确删除一个文档,需要指定justOne参数
db.member.remove({age:19},true)
  1. 删除多个文档
db.member.remove({age:19})
或
db.member.deleteMany({age:19})
  1. 删除全部文档
db.member.remove({})
或
db.member.deleteMany({})
或
db.member.drop()
# remove与deleteMany是对查询范围内的数据逐条删除,drop是删除整个集合(包括全部索引)drop更高效
  1. 删除并返回删除的数据findOneAndDelete

remove和deleteMany只能按照默认顺序删除,并返回确认信息。findOneAndDelete可以指定顺序删除文档和返回删除的内容文章来源地址https://www.toymoban.com/news/detail-620639.html

删除并返回

db.member.findOneAndDelete({age:18})

删除指定排序的数据

db.member.findOneAndDelete({age:18},{sort:{_id:-1}})

到了这里,关于MongoDB 的增、查、改、删的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • mongodb 数据库管理(数据库、集合、文档)

    目录 一、数据库操作 1、创建数据库 2、删除数据库 二、集合操作 1、创建集合 2、删除集合 三、文档操作 1、创建文档 2、 插入文档 3、查看文档 4、更新文档 1)update() 方法 2)replace() 方法 创建数据库的语法格式如下: 如果数据库不存在,则创建数据库,否则切换到该数据

    2024年02月12日
    浏览(49)
  • mongodb数据库操作

    1、启动mongodb 在mongodb启动命令中 --dbpath 指定mongodb的数据存储路径 --logpath 指定mongodb的日志存储路径 2、停止mongodb 第一步先进入mongo命令行模式 第二步,使用use admin 命令进入admin数据库 第三步,执行 db.shutdownServer()命令 停止服务。代码及显示如下:  2 、导出Mongodb数据 mon

    2024年02月09日
    浏览(50)
  • MongoDb数据库

    1.显示所有数据库: show dbs 2.切换到指定数据库,如果没有则自动创建数据库 use databaseName 3.显示当前所在数据库 db 4.删除当前数据库 use 库名 db.dropDatabase() 1.创建集合 db.createCollection(\\\'集合名称\\\') 2.显示当前数据库中所有集合 show colletions  3.删除某个集合 db.xxx.drop(); 4.重命名集

    2024年02月04日
    浏览(54)
  • MongoDB数据库安装

    MongoDB数据的特点: 面相文档存储的分布式数据库 具有很强的扩展性 支持丰富的查询表达式,很接近于关系性数据库 使用类似于json的结构保存数据,可以轻易的查询到文档中内嵌的对象及数组 首先去官网下载安装包 Download MongoDB Community Server | MongoDB 启动MongoDB数据的服务 可

    2024年02月11日
    浏览(57)
  • Mongodb连接数据库

    npm init   npm i mongoose  const mongoose=require(\\\"mongoose\\\") mongoose.connect(\\\"mongodb://127.0.0.1:27017/user\\\") 说明:mongodb是协议,user是数据库,如果没有会自动创建user数据库 。 node 文件名     mongoose.disconnect()

    2024年02月15日
    浏览(59)
  • 【数据库MongoDB】MongoDB与大数据关系以及MongoDB中重要的进程:mongod进程与mongo进程关系

    云计算的定义有多种说法,对于到底什么是云计算,我们至少可以找到100种解释。目前广为接受的是美国国家标准与技术研究院定义: 云计算是一种按使用量付费的模式,这种模式提供可用的、便捷的、按需的网络访问,进入可配置的计算资源共享池(资源包括网络、服务器

    2024年02月02日
    浏览(68)
  • MongoDB:数据库初步应用

    1.MongoDBCompass连接数据库 连接路径:mongodb://用户名:密码@localhost:27017/ 2.创建数据库(集合) MongoDB中数据库被称为集合.  MongoDBCompass连接后,点击红色框加号创建集合,点击蓝色框加号创建文档(数据表) 文档中的数据结构(相当于表中的列)设计不用管,添加数据的时候,自动创建列和数

    2024年02月12日
    浏览(47)
  • MongoDB 数据库详细介绍

    MongoDB(来自“Humongous”,意为巨大的)是一个开源、高性能、无模式(NoSQL)、文档导向的分布式数据库。它以其灵活性、可扩展性和强大的查询功能而闻名于世。MongoDB 使用 JSON 格式的文档来存储数据,适用于多种应用场景,包括 Web 应用、移动应用、日志存储、大数据等。

    2024年02月12日
    浏览(64)
  • python数据库——Mongodb

    MongoDB 是一个开源的 NoSQL数据库系统,它是一个面向文档的数据库,使用 JSON 格式来存储和查询数据。MongoDB 是一个非关系型数据库,它的设计目标是以高性能、高可用性和可扩展性为特点,适用于处理大量的非结构化数据。 特点: MongoDB 是一个面向文档存储的数据库,操作

    2024年02月07日
    浏览(55)
  • MongoDB 数据库性能优化技巧

    原文:MongoDB 数据库性能优化技巧 (techdatafuture.com) MongoDB 是一款灵活且可扩展的NoSQL数据库,为了提高其性能,我们可以采取一些优化技巧。本文将介绍一些MongoDB性能优化的关键点,包括索引的使用、查询优化、数据模型设计和硬件优化等。          1.合理使用索引     索

    2024年02月09日
    浏览(75)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包