python与mongodb交互-->pymongo

2023-09-17 18:43:39
from pymongo import MongoClient

# 创建数据库连接对象
client=MongoClient('ip',27017)

# 选择一个数据库
db=client['admin']

db.authenticate('python','python')

# 选择一个集合
col=client['pydata']['test']

col.insert({"class":"python"})

col.find()
for data in col.find():
    print(data)


# 更新
col.update({"class":"python40"},{"message":"hello word"})
# 全文档覆盖更新
col.update({},{"$set":{"id":"xxxx-xxxx"}})
col.update({},{"$set":{"id":"xxxx-xxxx"}},multi=True)
col.update({},{"$set":{"id":"xxxx-xxxx"}},upsert=True)

# 删除
col.delete_one({"":""})
col.delete_many({"":""})
  1. $match:根据指定的条件筛选出满足条件的文档,类似于查询操作中的查询条件。

  2. $group:根据指定的字段对文档进行分组,并可以对每个分组进行计算或汇总。可用于计算汇总值、计数、求和、平均值等。

  3. $project:对输入文档进行投影操作,选择需要的字段,并可以对字段进行重命名、计算、转换等操作。类似于查询操作中的投影(Projection)。

  4. $sort:根据指定的字段对文档进行排序,可以按升序或降序排序。

  5. $limit:限制结果集的文档数量,只返回指定数量的文档。

  6. $skip:跳过指定数量的文档,并返回剩余的文档。

  7. $unwind:将包含数组的字段拆分为多个文档,每个文档只包含数组中的一个元素。

  8. $lookup:在不同的集合之间执行左连接操作,可以从其他集合中获取匹配的文档。

这些是一些常见的聚合操作,您可以根据需求组合和使用不同的聚合操作符来构建复杂的聚合管道。聚合操作可以用于实现复杂的数据处理和分析任务,例如数据分组统计、数据透视、数据变换等。

以下是一个示例聚合管道的示例,以展示如何使用多个阶段来完成数据处理:

db.collection.aggregate([
  { $match: { field: value } },
  { $group: { _id: "$category", total: { $sum: "$quantity" } } },
  { $sort: { total: -1 } },
  { $limit: 5 }
]);

更多推荐

【Rust 基础篇】Rust 模式:高效、安全和灵活的匹配工具

导言在编程中,经常需要对数据进行匹配和处理,例如从一个复杂的数据结构中提取特定的值,或者根据不同的情况执行不同的逻辑。Rust是一门现代的系统编程语言,它引入了一种称为"模式"(Pattern)的强大特性,使得数据的匹配和处理变得高效、安全和灵活。本篇博客将深入探讨Rust模式的各种用法,带您领略Rust的魅力。什么是

ES6如何声明一个类?类如何继承?

在JavaScript中,您可以使用关键字class来声明一个类。类是一种模板,用于创建对象的构造函数,其中包含了属性和方法。以下是声明一个类的基本语法:classClassName{constructor(){//构造函数,用于创建对象实例时初始化属性this.propertyName=value;}//方法定义me

stm32学习-芯片系列/选型

【03】STM32·HAL库开发-初识STM32|STM概念、芯片分类、命名规则、选型|STM32原理图设计、看数据手册、最小系统的组成、STM32IO分配_小浪宝宝的博客-CSDN博客STM32:ST是意法半导体,M是MCU/MPU,32是32位。ST累计推出了:5大类、18个系列、1000多个型号的Cortex内核

注入之mssql数据库(手工注入)

sa最高权限(可以获取系统权限)打开一个mssql数据库要拼接一个参数拼接这个参数?xxser=1检查是否是mssql数据库andexists(select*from%20sysobjects)为真是属于mssql查询当前数据库系统的用户名andsystem_user=0(由于版本问题谷歌不可以)可以去虚拟机,爆出系统

基于讯飞人脸算法(调用API进行人脸比对)

先看结果必须遥遥领先基于讯飞人脸算法视频演示所需准备这里我调用了:人脸比对API文档|讯飞开放平台文档中心https://www.xfyun.cn/doc/face/xffaceComparisonRecg/API.html#%E6%8E%A5%E5%8F%A3%E8%AF%B4%E6%98%8E代码里所涉及的APPI

联盟 | Nativex 与 HelpLook 携手助力品牌独立站实现营销增长

近日,汇量科技旗下数字营销平台Nativex与AI知识库搭建工具HelpLook携手合作,共同推动中国跨境卖家和出海开发者的数字营销和客户服务,提供更广阔的增长空间。关于Nativex&HelpLook作为一家全球数字营销平台,Nativex不仅拥有丰富的数字营销经验,还在全球范围内积累了十余年的移动营销专业知识。Na

buuctf-ciscn_s_3

一、srop参考文章-博客园-wudiiv11(作者)-BUUCTF-ciscn_2019_s_3参考文章-博客园-z2yh(作者)-Srop原理与利用方法vlun函数中没有分配栈帧(指rsp没有增长,也没有压入父函数的rbp,这也导致之后的构造payload的时候不需要填充rbp的那8个字节)首先看中间这一栏,要找b

[运维|数据库] mysql的charset与PostgreSQL的encoding

在PostgreSQL数据库中,字符集(charset)的概念与MySQL有所不同。在PostgreSQL中,字符集通常由所谓的"编码"(encoding)来表示。每个数据库都可以使用不同的编码,以适应不同的字符集需求。以下是一些常见的PostgreSQL编码及其对应的MySQL字符集的替代方式:UTF-8(Unico

day31 代码随想录 分发饼干&摆动序列&最大子序和

大纲●理论基础●455.分发饼干●376.摆动序列●53.最大子序和455.分发饼干题目:455.分发饼干//分发饼干//有数组g代表胃口大小,数组s代表饼干大小//求满足最多胃口的值//思路是对gs排序//优先选择最大的饼干满足最大的胃口//[1,2,3][1,1]intfitChildVal(vector<int>

Multitor:一款带有负载均衡功能的多Tor实例创建工具

关于MultitorMultitor是一款带有负载均衡功能的多Tor实例创建工具,Multitor的主要目的是以最快的速度完成大量Tor进程的初始化,并将大量实例应用到我们日常使用的程序中,例如Web浏览器和聊天工具等等。除此之外,在该工具的帮助下,我们还可以在进行渗透测试和对基础设施安全性进行审计时提高隐蔽性和匿名性

【校招VIP】前端操作系统之I/O调度算法

考点介绍I/O调度算法在各个进程竞争磁盘I/O的时候担当了裁判的角色。他要求请求的次序和时机做最优化的处理,以求得尽可能最好的整体I/O性能。前端操作系统之I/O调度算法-相关题目及解析内容可点击文章末尾链接查看!一、考点题目1.某文件占10个磁盘块,现要把该文件磁盘块逐个读入主存缓冲区,并送用户区进行分析,假设一个缓

热文推荐