【mongo 系列】常用操作实际操练

2023-10-25 09:50

本文主要是介绍【mongo 系列】常用操作实际操练,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【mongo 系列】常用操作实际操练

插入数据

> db.users.insert({"name" : "xiaomotong""age" : 18})

>
 db.users.insert({name:"xiaozhu",age:15,hobby:"basketball",infos:{tall:190,height:70},school:"sh"})

>
 db.users.insertMany([{name:"xiaopang"},{name:"wangwu"}])

>
 db.users.insertMany([{name:"nancy""age" :25, "hobby" : "study""infos" : { "tall" : 175, "height" : 60 }, "school" : "hn" },{name:"job""age" : 19, "hobby" : "basketball""infos" : { "tall" : 170, "height" : 70 }, "school" : "nj" }])
  • 可以使用 insert,insertOne,insertMany 插入不同的数据,各取所需,其中 insertMany 用于插入多条数据,当然也可以插入 1 条数据

mongodb 在插入数据上面还有这么多函数方法可以使用,各取所需

更新数据


>
 db.users.find()
{ "_id" : ObjectId("61584aeeee74dfe04dac57e9"), "name" : "xiaomotong", "age" : 18 }
...

>
 db.users.update({name:"xiaomotong"},{$set:{name:"xiaokeai",age:25,hobby:"reading",infos:{tall:175,height:62},school:"cs"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

使用 $set 表示需要更新字段

查询数据的时候我们发现,mongodb 自动在我们的文档中加入了 _id 字段,这是一个主键,如果不自己设置的话,mongodb 为默认给我们加上,是一个 24 位的 uuid

关于更新的方法,官网还提供了这些方法:

查找数据

> db.users.find({"infos.tall":{$gt:170}})
{ "_id" : ObjectId("61584aeeee74dfe04dac57e9"), "name" : "xiaokeai", "age" : 25, "hobby" : "reading", "infos" : { "tall" : 175, "height" : 62 }, "school" : "cs" }
{ "_id" : ObjectId("615a56d6bc6afecd2cff8f96"), "name" : "xiaozhu", "age" : 15, "hobby" : "basketball", "infos" : { "tall" : 190, "height" : 70 }, "school" : "sh" }
{ "_id" : ObjectId("615a5917d988690b07c69f66"), "name" : "nancy", "age" : 25, "hobby" : "study", "infos" : { "tall" : 175, "height" : 60 }, "school" : "hn" }

此处的 $gt 是大于 的意思,上期有说到这些运算符,再来回顾一遍

上述 infos.tall 属于子查询,表示 infos 是一个内嵌文档,需要查找的是 文档中的 tall 字段,我们也不能不加双引号,因为系统会默认识别 infos.tall 为一个字段,实际上是找不到这个字段的,因此是查询不到结果的,如下报错:

> db.users.find({infos.tall:{$gt:170}})
2021-10-04T09:39:21.349+0800 E  QUERY    [js] uncaught exception: SyntaxError: missing : after property id :
@(shell):1:20

以更加友好的方式查询数据展示出来

> db.users.find({"infos.tall":{$gte:180}}).pretty()
{
        "_id" : ObjectId("615a56d6bc6afecd2cff8f96"),
        "name" : "xiaozhu",
        "age" : 15,
        "hobby" : "basketball",
        "infos" : {
                "tall" : 190,
                "height" : 70
        },
        "school" : "sh"
}

此处的 db.users.find({"infos.tall":{$gte:180}}) 就类似于关系型数据库的 sql 语句:select * from users where "infos.tall" >= 180

例如查询,身高在 是 175 或者 190 的学生.

此处的 db.users.find({"infos.tall":{$in:[190,175]}}) 就类似与关系型数据库的 select * from users where "infos.tall" in (190,175)

演示一下简单的正则表达式:

> db.users.find({name:/^w/}).pretty()
{ "_id" : ObjectId("615a5856d988690b07c69f65"), "name" : "wangwu" }
> db.users.find({name:/g$/}).pretty()
{ "_id" : ObjectId("615a5856d988690b07c69f64"), "name" : "xiaopang" }
  • 查询 name 字段,匹配 w 开头的结果,匹配出来 wangwu
  • 查询 name 资源,匹配 g 结尾的结果,匹配出来 xiaotong

此处在我们查询的时候,/正则表达式/,mongodb 会自动识别并按照正则表达式的规则进行匹配和处理

我们也可以查询 null

> db.users.find({infos:null})
{ "_id" : ObjectId("615a5856d988690b07c69f64"), "name" : "xiaopang" }
{ "_id" : ObjectId("615a5856d988690b07c69f65"), "name" : "wangwu" }

>
 db.users.find({infos:{$exists:false}})
{ "_id" : ObjectId("615a5856d988690b07c69f64"), "name" : "xiaopang" }

查询字段为 null 可以使用第一种方式,查询字段不存在可以使用第二种方式

删除数据

> db.users.deleteOne({name:"wangwu"})
{ "acknowledged" : true, "deletedCount" : 1 }
> db.users.find({name:/^w/}).pretty()
>

常用的删除方法有:

  • db.users.deleteOne()
  • db.users.deleteMany()
  • db.users.remove()

简单分页查询

> use mytest
switched to db mytest
> db.users.find()
{ "_id" : ObjectId("61584aeeee74dfe04dac57e9"), "name" : "xiaokeai", "age" : 25, "hobby" : "reading", "infos" : { "tall" : 175, "height" : 62 }, "school" : "cs" }
{ "_id" : ObjectId("615a56d6bc6afecd2cff8f96"), "name" : "xiaozhu", "age" : 15, "hobby" : "basketball", "infos" : { "tall" : 190, "height" : 70 }, "school" : "sh" }
{ "_id" : ObjectId("615a5856d988690b07c69f64"), "name" : "xiaopang" }
{ "_id" : ObjectId("615a5917d988690b07c69f66"), "name" : "nancy", "age" : 25, "hobby" : "study", "infos" : { "tall" : 175, "height" : 60 }, "school" : "hn" }
{ "_id" : ObjectId("615a5917d988690b07c69f67"), "name" : "job", "age" : 19, "hobby" : "basketball", "infos" : { "tall" : 170, "height" : 70 }, "school" : "nj" }

>
 db.users.find().limit(2)
{ "_id" : ObjectId("61584aeeee74dfe04dac57e9"), "name" : "xiaokeai", "age" : 25, "hobby" : "reading", "infos" : { "tall" : 175, "height" : 62 }, "school" : "cs" }
{ "_id" : ObjectId("615a56d6bc6afecd2cff8f96"), "name" : "xiaozhu", "age" : 15, "hobby" : "basketball", "infos" : { "tall" : 190, "height" : 70 }, "school" : "sh" }

>
 db.users.find().skip(2).limit(2)
{ "_id" : ObjectId("615a5856d988690b07c69f64"), "name" : "xiaopang" }
{ "_id" : ObjectId("615a5917d988690b07c69f66"), "name" : "nancy", "age" : 25, "hobby" : "study", "infos" : { "tall" : 175, "height" : 60 }, "school" : "hn" }

  • db.users.find() 查询所有的数据,按照默认的顺序打印出来
  • db.users.find().limit(2) 从前面的结果中,限制取出 2 条
  • db.users.find().skip(2).limit(2)从前面的结果中,偏移 2 条,再限制取出 2 条

下一次,梳理聚合相关内容

官方一手资料:https://docs.mongodb.com/manual/reference

欢迎点赞,关注,收藏

朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是阿兵云原生,欢迎点赞关注收藏,下次见~

这篇关于【mongo 系列】常用操作实际操练的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/281752

相关文章

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Java Multimap实现类与操作的具体示例

《JavaMultimap实现类与操作的具体示例》Multimap出现在Google的Guava库中,它为Java提供了更加灵活的集合操作,:本文主要介绍JavaMultimap实现类与操作的... 目录一、Multimap 概述Multimap 主要特点:二、Multimap 实现类1. ListMult

Java 枚举的基本使用方法及实际使用场景

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav... 目录一、什么是枚举?二、枚举的基本使用方法定义枚举三、实际使用场景代替常量状态机四、更多用法1.实现接

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.