Python私教MongoDB快速入门教程

2024-01-11 23:12

本文主要是介绍Python私教MongoDB快速入门教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Docker安装MongoDB

拉取镜像:

docker pull mongo:6.0.2

创建容器:

docker run --name mongo -d -p 27017:27017 mongo:6.0.2

设置用户名和密码:

# 创建mongo容器后,进入容器
docker exec -it mongo bash# 进入mongo shell
mongosh# 进入admin数据库
use admin# 创建用户名和密码
db.createUser({user:'zhangdapeng',pwd:'zhangdapeng520',roles:[{role:'root',db:'admin'}]})

校验用户名和密码:

# 认证登录db.auth('用户名','密码'),打印1则代表认证通过
db.auth('zhangdapeng','zhangdapeng520')

数据库管理

创建数据库:

use db;

查看所有数据库:

show dbs

插入一条数据,再查看所有数据库:

db.db.insertOne({"name":"张大鹏"})
show dbs

删除数据库:

db.dropDatabase()
show dbs

集合管理

集合相当于一张表,创建一张user集合:

use test
db.createCollection("user")

查看所有的集合:

show collections

创建固定集合 mycol,整个集合空间大小 6142800 B, 文档最大个数为 10000 个。

db.createCollection("mycol", {capped: true, autoIndexId: true, size: 6142800, max: 10000 })
show collections

在 MongoDB 中,你不需要创建集合。当你插入一些文档时,MongoDB 会自动创建集合。

db.mycol2.insert({"name" : "张大鹏"})
show collections

删除集合:

db.mycol2.drop()
show collections

新增文档

向user集合中新增张三:

db.user.insert({name: '张三', age: 22})
show collections

查询所有的用户:

db.user.find()

向user集合中新增李四:

db.user.insertOne({name: '李四', age: 24})
db.user.find()

向user集合中新增赵六和田七:

db.user.insertMany([{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()

更新文档

update() 方法

update() 方法用于更新已存在的文档。语法格式如下:

db.collection.update(<query>,<update>,{upsert: <boolean>,multi: <boolean>,writeConcern: <document>}
)

参数说明:

  • query : update的查询条件,类似sql update查询内where后面的。
  • update : update的对象和一些更新的操作符(如 , , ,inc…)等,也可以理解为sql update查询内set后面的
  • upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
  • multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
  • writeConcern :可选,抛出异常的级别。

实战案例

将张三修改为张三333:

db.user.find()
db.user.update({'name':'张三'},{$set:{'name':'张三333'}})
db.user.find()

更多实例

只更新第一条记录:

db.col.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } );

全部更新:

db.col.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true );

只添加第一条:

db.col.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false );

全部添加进去:

db.col.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true );

全部更新:

db.col.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );

只更新第一条记录:

db.col.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );

使用updateOne修改

db.user.updateOne({"name":"李四"},{$set:{"age":34}})

使用updateMany修改

db.user.updateMany({"age":{$gt:30}},{$set:{"age":33}})

删除文档

实战案例

删除张三:

db.user.find()
db.col.remove({'name':'张三'})
db.user.find()

deleteOne删除

删除张三333:

db.user.find()
db.user.deleteOne({'name':'张三333'})
db.user.find()

deleteMany删除

删除李四:

db.user.find()
db.user.deleteMany({'name':'李四'})
db.user.find()

删除年龄大于30的用户:

db.user.deleteMany({"age":{$gt:30}})

findOneAndDelete删除

删除赵六:

db.user.find()
db.user.findOneAndDelete({'name':'赵六'})
db.user.find()

查询文档

条件运算符

操作格式范例RDBMS中的类似语句
等于{<key>:<value>}db.col.find({"by":"张三"}).pretty()where by = '张三'
小于{<key>:{$lt:<value>}}db.col.find({"likes":{$lt:50}}).pretty()where likes < 50
小于或等于{<key>:{$lte:<value>}}db.col.find({"likes":{$lte:50}}).pretty()where likes <= 50
大于{<key>:{$gt:<value>}}db.col.find({"likes":{$gt:50}}).pretty()where likes > 50
大于或等于{<key>:{$gte:<value>}}db.col.find({"likes":{$gte:50}}).pretty()where likes >= 50
不等于{<key>:{$ne:<value>}}db.col.find({"likes":{$ne:50}}).pretty()where likes != 50

逻辑运算符

and运算:

db.col.find({key1:value1, key2:value2}).pretty()

or运算:

db.col.find({$or: [{key1: value1}, {key2:value2}]}
).pretty()

实战案例

查询名字叫张三的:

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询
db.user.find({"name":"张三"})

查询年龄小于30的:

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询
db.user.find({"age":{$lt:30}})

查看年龄小于30且大于25的:

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询
db.user.find({"age":{$lt:30,$gt:25}})

查看名字叫张三或者名字叫李四的:

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询
db.user.find({$or:[{"name":"张三"},{"name":"l"}]})

分页查询

实战案例

每页2条数据,查询第2页:

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询
db.user.find().limit(2).skip(2)

根据年龄排序,每页2条数据,查询第2页:在 MongoDB 中使用 sort() 方法对数据进行排序,sort() 方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而 -1 是用于降序排列。

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询
db.user.find().sort({}).limit(2).skip(2)

聚合查询

聚合语法

表达式描述实例
$sum计算总和。db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", num_tutorial : { s u m : " sum : " sum:"likes"}}}])
$avg计算平均值db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", num_tutorial : { a v g : " avg : " avg:"likes"}}}])
$min获取集合中所有文档对应值得最小值。db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", num_tutorial : { m i n : " min : " min:"likes"}}}])
$max获取集合中所有文档对应值得最大值。db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", num_tutorial : { m a x : " max : " max:"likes"}}}])
$push将值加入一个数组中,不会判断是否有重复的值。db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", url : { p u s h : " push: " push:"url"}}}])
$addToSet将值加入一个数组中,会判断是否有重复的值,若相同的值在数组中已经存在了,则不加入。db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", url : { a d d T o S e t : " addToSet : " addToSet:"url"}}}])
$first根据资源文档的排序获取第一个文档数据。db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", first_url : { f i r s t : " first : " first:"url"}}}])
$last根据资源文档的排序获取最后一个文档数据db.mycol.aggregate([{KaTeX parse error: Expected '}', got 'EOF' at end of input: …roup : {_id : "by_user", last_url : { l a s t : " last : " last:"url"}}}])

常用操作

这里我们介绍一下聚合框架中常用的几个操作:

  • $project:修改输入文档的结构。可以用来重命名、增加或删除域,也可以用于创建计算结果以及嵌套文档。
  • m a t c h :用于过滤数据,只输出符合条件的文档。 match:用于过滤数据,只输出符合条件的文档。 match:用于过滤数据,只输出符合条件的文档。match使用MongoDB的标准查询操作。
  • $limit:用来限制MongoDB聚合管道返回的文档数。
  • $skip:在聚合管道中跳过指定数量的文档,并返回余下的文档。
  • $unwind:将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值。
  • $group:将集合中的文档分组,可用于统计结果。
  • $sort:将输入文档排序后输出。
  • $geoNear:输出接近某一地理位置的有序文档。

实战案例

查询用户总数:

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询
db.user.countDocuments()

查询用户平均年龄:

# 删除集合
db.user.drop()# 批量新增
db.user.insertMany([{name: '李四', age: 34},{name: '张三', age: 23},{name: '赵六', age: 26},{name: '田七', age: 27}])
db.user.find()# 查询用户数量和平均年龄
db.user.aggregate([{$group:{_id: null, total_num: {$sum:1},total_avg: {$avg: "$age"}}}])

这篇关于Python私教MongoDB快速入门教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财