MongoDB的简单介绍:

1:MongoDB是什么?

  • mongodb是非关系数据库 但是是非关系数据库当中功能最丰富,最像关系数据库的
  • MongoDB是一个基于分布式文件存储的数据库。
  • C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

2:MongoDB的三大特点:

  • 高性能
  • 易部署
  • 易使用
  • 存储数据非常方便
  • 支持 GolangRUBYPYTHONJAVAC++PHPC#等多种语言
  • 文件存储格式为BSON(一种JSON的扩展)。

3:先来介绍我们的插入语句吧

1:插入语句:

插入一条数据:

> db.jie.insert({name:"jie",age:18})
WriteResult({ "nInserted" : 1 })

可以使用:db.集合名.find()查看 

> db.jie.find()
{ "_id" : ObjectId("6069ac8300fc7b062bb3ed94"), "name" : "jie", "age" : 18 }
这里id可以自己设置
可以指定id 不过最好不要指定

插入多条:

> db.jie.insert([{name:"luyunjie",age:18},{name:"jiebao",age:19}])
BulkWriteResult({
"writeErrors" : [ ],
"writeConcernErrors" : [ ],
"nInserted" : 2,
"nUpserted" : 0,
"nMatched" : 0,
"nModified" : 0,
"nRemoved" : 0,
"upserted" : [ ]
})

mongodb也可以使用js语法 用for循环插入多条数据:

> for (var i=1;i<=10;i++){
db.jie1.insert({name: "jie"+i,age: i})
}
WriteResult({ "nInserted" : 1 })
这里不为10是因为for循环是一条一条插入
然后只显示最后一条插入的数量 单用find()查看还是可以查看10条数据

> db.jie1.find()
{ "_id" : ObjectId("6069b34700fc7b062bb3ed97"), "name" : "jie1", "age" : 1 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed98"), "name" : "jie2", "age" : 2 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed99"), "name" : "jie3", "age" : 3 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9a"), "name" : "jie4", "age" : 4 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9b"), "name" : "jie5", "age" : 5 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9c"), "name" : "jie6", "age" : 6 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9d"), "name" : "jie7", "age" : 7 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9e"), "name" : "jie8", "age" : 8 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9f"), "name" : "jie9", "age" : 9 }
{ "_id" : ObjectId("6069b34700fc7b062bb3eda0"), "name" : "jie10", "age" : 10 }

2:查询语句

基本的运算符介绍:

出几个题目 配合查询语句来一一实现:

1:只查询字段name的值:

> db.jie1.find({},{name:1})
{ "_id" : ObjectId("6069b34700fc7b062bb3ed97"), "name" : "jie1" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed98"), "name" : "jie2" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed99"), "name" : "jie3" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9a"), "name" : "jie4" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9b"), "name" : "jie5" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9c"), "name" : "jie6" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9d"), "name" : "jie7" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9e"), "name" : "jie8" }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9f"), "name" : "jie9" }
{ "_id" : ObjectId("6069b34700fc7b062bb3eda0"), "name" : "jie10" }
无论查询什么 id都会一直在的

2:查询age大于5 小于8的所有数据:

> db.jie1.find({age:{$gte:5,$lte:8}})
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9b"), "name" : "jie5", "age" : 5 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9c"), "name" : "jie6", "age" : 6 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9d"), "name" : "jie7", "age" : 7 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9e"), "name" : "jie8", "age" : 8 }
运用我们的运算符来达到效果 运算符的语法是
  db.集合名.find(

    键:{运算符:值}
)

3:查询age为1,4, 5, 9 的所有数据:

> db.jie1.find({age:{$in:[1,4,5,9]}})
{ "_id" : ObjectId("6069b34700fc7b062bb3ed97"), "name" : "jie1", "age" : 1 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9a"), "name" : "jie4", "age" : 4 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9b"), "name" : "jie5", "age" : 5 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9f"), "name" : "jie9", "age" : 9 }
运用运算符达到效果

4:把age倒序排列(运用sort()来排序):

> db.jie1.find().sort({age:-1})
{ "_id" : ObjectId("606a79d6945dd5f6933d5845"), "name" : "jie10", "age" : 10 }
{ "_id" : ObjectId("606a79d6945dd5f6933d5844"), "name" : "jie9", "age" : 9 }
{ "_id" : ObjectId("606a79d6945dd5f6933d5843"), "name" : "jie8", "age" : 8 }
{ "_id" : ObjectId("606a79d6945dd5f6933d5842"), "name" : "jie7", "age" : 7 }
{ "_id" : ObjectId("606a79d6945dd5f6933d5841"), "name" : "jie6", "age" : 6 }
{ "_id" : ObjectId("606a79d6945dd5f6933d5840"), "name" : "jie5", "age" : 5 }
{ "_id" : ObjectId("606a79d6945dd5f6933d583f"), "name" : "jie4", "age" : 4 }
{ "_id" : ObjectId("606a79d6945dd5f6933d583e"), "name" : "jie3", "age" : 3 }
{ "_id" : ObjectId("606a79d6945dd5f6933d583d"), "name" : "jie2", "age" : 2 }
{ "_id" : ObjectId("606a79d6945dd5f6933d583c"), "name" : "jie1", "age" : 1 }
运用sort()来进行倒序
语法:db.集合名.find().sort({查询的字段:
-1 })
-1为倒序 1为正序

聚合函数:

简单介绍一下聚合函数的管道:

                                

表达式 描述 实例
$sum 计算总和。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$sum : "$likes"}}}])
$avg 计算平均值 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$avg : "$likes"}}}])
$min 获取集合中所有文档对应值得最小值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$min : "$likes"}}}])
$max 获取集合中所有文档对应值得最大值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$max : "$likes"}}}])
$push 在结果文档中插入值到一个数组中。 db.mycol.aggregate([{$group : {_id : "$by_user", url : {$push: "$url"}}}])
$addToSet 在结果文档中插入值到一个数组中,但不创建副本。 db.mycol.aggregate([{$group : {_id : "$by_user", url : {$addToSet : "$url"}}}])
$first 根据资源文档的排序获取第一个文档数据。 db.mycol.aggregate([{$group : {_id : "$by_user", first_url : {$first : "$url"}}}])
$last 根据资源文档的排序获取最后一个文档数据 db.mycol.aggregate([{$group : {_id : "$by_user", last_url : {$last : "$url"}}}])

 聚合函数语法:

db.集合名.aggregate([
{管道:{ 表达式}
....
]})

题目自测:

1:统计男生,女生的总年龄:

准备数据:
db.xiaojie3.insert([
{name:"小杰",sex:1,age:18},
{name:"杰宝",sex:1,age:19},
{name:"小红",sex:2,age:20},
{name:"小青",sex:2,age:16}
])
代码:
db.xiaojie3.aggregate([
{$group:{
_id:"$sex",
num:{$sum:"$age"}
}
}])

分页查询(skip和limit):

语法:

db.集合名.find().skip(跳过多少条的数字).limit(查询多少条的数字)
skip是可选值 可不添加

练习题目

1:只查询age为10和9的数据:

> db.jie1.find().sort({age:-1}).limit(2)
{ "_id" : ObjectId("606a79d6945dd5f6933d5845"), "name" : "jie10", "age" : 10 }
{ "_id" : ObjectId("606a79d6945dd5f6933d5844"), "name" : "jie9", "age" : 9 }

 2:降序跳过4条数据 查4条:

> db.jie1.find().sort({age:-1}).skip(4).limit(4)
{ "_id" : ObjectId("606a79d6945dd5f6933d5841"), "name" : "jie6", "age" : 6 }
{ "_id" : ObjectId("606a79d6945dd5f6933d5840"), "name" : "jie5", "age" : 5 }
{ "_id" : ObjectId("606a79d6945dd5f6933d583f"), "name" : "jie4", "age" : 4 }
{ "_id" : ObjectId("606a79d6945dd5f6933d583e"), "name" : "jie3", "age" : 3

3:修改(更新)语句:

修改器的基本介绍:

如果不用修改器来修改数据 则是替换

列子:

> db.jie.update({name:"jie"},{name:"xiaojie"})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.jie.find()
{ "_id" : ObjectId("6069ac8300fc7b062bb3ed94"), "name" : "xiaojie" }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed95"), "name" : "luyunjie", "age" : 18 }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed96"), "name" : "jiebao", "age" : 19 }
>
到达的是替换的效果

我们继续举列子来讲解:

1:修改name为luyunjie的字段 把luyunjie改为xiaojiejie其他不变:

> db.jie.update({name:"luyunjie"},{$set:{name:"xiaojiejie"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.jie.find()
{ "_id" : ObjectId("6069ac8300fc7b062bb3ed94"), "name" : "xiaojie" }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed95"), "name" : "xiaojiejie", "age" : 18 }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed96"), "name" : "jiebao", "age" : 19 }
修改成功 运用修改器
修改器语法:
db.集合名.updata(
{修改的值},
{修改器:{修改的值}
})

2:给age为20的数据递加或递减5:

递增:

> db.jie.update({age:20},{$inc:{age:5}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.jie.find()
{ "_id" : ObjectId("6069ac8300fc7b062bb3ed94"), "name" : "xiaojie" }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed95"), "name" : "xiaojiejie", "age" : 25 }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed96"), "name" : "jiebao", "age" : 19 }

递减:

> db.jie.update({age:18},{$inc:{age:-5}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.jie.find()
{ "_id" : ObjectId("6069ac8300fc7b062bb3ed94"), "name" : "xiaojie" }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed95"), "name" : "xiaojiejie", "age" : 20 }
{ "_id" : ObjectId("6069ad8700fc7b062bb3ed96"), "name" : "jiebao", "age" : 19 }
>

3:练习为修改器为修改多个值

题目:把name里面的数据改为小杰,age数据递增20,sex字段删除,dta字段改为bianhao;

准备数据:

> db.xiaojie.insert({name:"jie",age:20,sex:"boy",dta:"123"})
WriteResult({ "nInserted" : 1 })
> db.xiaojie.find()
{ "_id" : ObjectId("6069c59800fc7b062bb3eda1"), "name" : "jie", "age" : 20, "sex" : "boy", "dta" : "123" }

题目答案:

> db.xiaojie.update({name:"jie"},{$set:{name:"小杰"},$inc:{age:20},$rename:{dta:"bianhao"},$unset:{sex:true}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.xiaojie.find()
{ "_id" : ObjectId("6069c59800fc7b062bb3eda1"), "name" : "小杰", "age" : 40, "bianhao" : "123" }
这里有几个点 多条语句的写法如上 db.集合名.update
({修改字段:字段值}, {
修改器:{},
修改器:{},
修改器:{},
修改器:{}
})

4:删除语句:

删除语法是:

db.集合名.remove({条件},是否删除一条)

1:删除一条数据:

> db.jie1.remove({},true)
WriteResult({ "nRemoved" : 1 })
> db.jie1.find()
{ "_id" : ObjectId("6069b34700fc7b062bb3ed98"), "name" : "jie2", "age" : 2 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed99"), "name" : "jie3", "age" : 3 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9a"), "name" : "jie4", "age" : 4 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9b"), "name" : "jie5", "age" : 5 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9c"), "name" : "jie6", "age" : 6 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9d"), "name" : "jie7", "age" : 7 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9e"), "name" : "jie8", "age" : 8 }
{ "_id" : ObjectId("6069b34700fc7b062bb3ed9f"), "name" : "jie9", "age" : 9 }
{ "_id" : ObjectId("6069b34700fc7b062bb3eda0"), "name" : "jie10", "age" : 10 }

2:删除全部数据:

> db.jie1.remove({})
WriteResult({ "nRemoved" : 9 })

简单介绍了一下MongoDB的CRUD操作 这篇博客会慢慢完善成MongoDB笔记 加油一起努力!

MongoDB的CRUD操作(入门)的更多相关文章

  1. MongoDB的CRUD操作

    1. 前言 在上一篇文章中,我们介绍了MongoDB.现在,我们来看下如何在MongoDB中进行常规的CRUD操作.毕竟,作为一个存储系统,它的基本功能就是对数据进行增删改查操作. MongoDB中的 ...

  2. 【翻译】MongoDB指南/CRUD操作(四)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(四) 1 查询方案(Query Plans) MongoDB 查询优化程序处理查询并且针对给定可利用的索引选 ...

  3. 【翻译】MongoDB指南/CRUD操作(三)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...

  4. 【翻译】MongoDB指南/CRUD操作(二)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...

  5. 【翻译】MongoDB指南/CRUD操作(一)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...

  6. Mongodb系列- CRUD操作介绍

    ---恢复内容开始--- 一 Create 操作 在MongoDB中,插入操作的目标是一个集合. MongoDB中的所有写入操作在单个文档的层次上都是原子的. For examples, see In ...

  7. MongoDB的CRUD操作(java Util )

    1.保存插入操作: public static synchronized String insert(DBObject record) { DBCollection col = MongoDB.get ...

  8. 实例讲解Springboot整合MongoDB进行CRUD操作的两种方式

    1 简介 Springboot是最简单的使用Spring的方式,而MongoDB是最流行的NoSQL数据库.两者在分布式.微服务架构中使用率极高,本文将用实例介绍如何在Springboot中整合Mon ...

  9. Spring Data MongoDB 一:入门篇(环境搭建、简单的CRUD操作)

    一.简介 Spring Data  MongoDB 项目提供与MongoDB文档数据库的集成.Spring Data MongoDB POJO的关键功能区域为中心的模型与MongoDB的DBColle ...

  10. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

    上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...

随机推荐

  1. 在Go中如何实现并发

    Go语言的并发机制是其强大和流行的一个关键特性之一.Go使用协程(goroutines)和通道(channels)来实现并发编程,这使得编写高效且可维护的并发代码变得相对容易.下面是Go的并发机制的详 ...

  2. PHPStudy hosts文件可能不存在或被阻止打开及同步hosts失败问题

    在使用PHPStudy建站包时,有时会遇到同步hosts失败的问题,可能是因为hosts文件不存在或被阻止打开.这个问题通常可以通过以下几个步骤解决: 步骤一:检查hosts文件是否存在 首先,我们需 ...

  3. Python的23种设计模式

    文章目录 Python与设计模式--前言 一 什么是设计模式 二 为什么要有设计模式 三 有那些设计模式 创建类设计模式(5种) 结构类设计模式(7种) 行为类设计模式(11种) 四 设计模式与架构, ...

  4. 2020/4/26 2-sat 学习笔记

    2-sat 吧.... 其实我jio得它一点都不难 嗯 2-sat是个啥东西呢?其实就是有很多人,他们每个人有两个要求,一个要求可以说是要求一个数为0或1而对于第i个数,我们可以选择为0或为1最终询问 ...

  5. 畅捷通T+任意文件上传(CNVD-2022-60632 )漏洞复现

    一.漏洞描述 022年8月29日和8月30日,畅捷通公司紧急发布安全补丁修复了畅捷通T+软件任意文件上传漏洞.未经身份认证的攻击者利用该漏洞,通过绕过系统鉴权,在特定配置环境下实现任意文件的上传,从而 ...

  6. 标子查询优化和改写SQL案例

    京华开发一哥们找我优化条报表SQL,反馈执行时间很慢需要 18s 才能出结果,安排. -- 原SQL SELECT 2 AS TYPE, to_char(a."create_time&quo ...

  7. 前端本地导出文件 导出txt sql (简版版的字符串案例)

    1.首页明确要导出的根据 一般有图片 excel  文字.针对不同的文件类型 配置不同的参数 2.知识点 Blob          URL.createObjectUrl new Blob( arr ...

  8. 持续集成指南:GitHubAction 自动构建+部署AspNetCore项目

    前言 之前研究了使用 GitHub Action 自动构建和发布 nuget 包:开发现代化的.NetCore控制台程序:(4)使用GithubAction自动构建以及发布nuget包 现在更进一步, ...

  9. 文心一言 VS 讯飞星火 VS chatgpt (138)-- 算法导论11.4 2题

    二.用go语言,试写出HASH-DELETE 的伪代码;修改 HASH-INSERT,使之能处理特殊值DELETED. 文心一言: 首先,让我们定义一个基本的哈希表数据结构.这个结构将包括一个存储键值 ...

  10. 大立科技DM63红外相机SDK开发Ⅰ-连接仪器

    1.开发准备 为了方便发开,需要下载Visual Studio,本开发基于Visual Studio 2022,使用C++. 通过Visual Studio创建好项目后,将DMSDK V1.16.3内 ...