mongodb 基础查询使用

  1. 环境安装
    https://blog.csdn.net/qq_42402648/article/details/134932412
    net start MongoDB 启动
    net stop MongoDB 停止
  2. 测试插入数据结构
{"create_time": {"$data": "1711244538176"},"language": "en","create_time01": "1711244538176","source": "ximalaya","time": 848
}
  1. 数据基础查询
	 查询source为ximalaya{"source":"ximalaya"}查询source为ximalaya,language为 zh {"source":"ximalaya","language":"zh"}查询source为ximalaya,time<300{"source":"ximalaya","time":{"$lt":300}}查询source为ximalaya,language为zh或者ko{"source":"ximalaya","language":{"$in":["jp","ko"]}}查询source为null  falsenull,true 不为null{"source":{"$exists":false}}根据time降序 -1降序,1 升序{"time":-1}
  1. 聚合查询
统计language为zh的总数
[{$match: {language: "zh",}},{$count: 'language_count'}
]根据source分组统计总数
[{$group: {_id: "$source",count: {$sum: 1}}}
]
根据source分组统计所有time和
[{$group: {_id: "$source",count: {$sum: 1,},time_sum: {$sum: "$time",},},},
]
数组文档拆分 ,一拆多行数据
[{$unwind:  "$tag"},
]
关联表查询
[{$match: {source: "qintin",},},{$lookup: {from: "base_info_v2",localField: "v2_id",foreignField: "id",as: "v2Info",},},
]
  1. 管道操作符
 $project 指定输出的字段
[{$project: {sourceName: "$source",date:"$time",},},
]$match 添加过滤条件
[{$match: {source:"youtube"}},{$project: {sourceName: "$source",date:"$time",},},
]$count 统计结果总数
[{$match: {source:"youtube"}},{$count: 'sourceCount'}
]分组后将输出结果使用project重新命名
[{$group: {_id: "$source",count:{$sum:1}}},{$project: {source:"$_id",count:"$count"}}
]

根据时间分组(时间格式化)
再根据source分组 统计出每天每个来源的总数
将分组后的数据重新命名 ,再次根据时间分组
最后 根据时间 升序排序

[{$group: {_id: {date: {$dateToString: {format: "%Y-%m-%d",date: "$create_time",},},source: "$source",},count: {$sum: 1,},},},{$project: {date: "$_id.date",source: "$_id.source",count: "$count",},},{$group: {_id: "$date",positions: {$push: {source: "$source",count: "$count",},},},},{$sort: {_id: 1}}
]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/791934.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI绘画:Stable Diffusion的高效操作界面,ComfyUI:安装和使用篇

前言 Stable Diffusion&#xff08;简称SD&#xff09;是一款强大的AI绘画工具&#xff0c;通常通过Web UI操作界面进行使用。然而&#xff0c;对于那些寻求更高效率和个性化工作流的用户来说&#xff0c;ComfyUI提供了一个基于节点流程的操作界面&#xff0c;使得工作流定制更…

文献分享:《Clinical metagenomics》

摘要|临床宏基因组下一代测序&#xff08;mNGS&#xff09;是对患者样本中微生物和宿主遗传物质&#xff08;DNA和RNA&#xff09;的综合分析&#xff0c;目前正迅速从研究向临床实验室发展。这种新兴的方法正在改变医生诊断和治疗传染病的方式&#xff0c;其应用涉及广泛的领域…

Java快速入门系列-1(Java概述)

第一章&#xff1a;Java概述 1.1 Java的发展历程1.2 Java的特点与优势1.2.1 特点1.2.2 优势 1.3 Java生态系统介绍1.4 Java在当前技术领域的应用案例 1.1 Java的发展历程 Java语言由Sun Microsystems公司于1995年推出&#xff0c;由James Gosling领导的Green Team小组研发而成…

【深度学习】入门深度学习相关

1.知识点&&小问题 参考视频&#xff1a;最详细的 Windows 下 PyTorch 入门深度学习环境安装与配置 CPU GPU 版 | 土堆教程 1.Pytorch和TensorFlow都是python的包/库。 2.为什么使用Anaconda&#xff1f;Anaconda的优势是有虚拟环境。 3.计算机底层对于Python语言&…

git branch 是干什么的

git branch 是 Git 版本控制系统中的一个命令&#xff0c;用于列出、创建、删除和重命名仓库中的分支。分支在 Git 中是一个非常重要的概念&#xff0c;它允许开发者在主线&#xff08;通常是 master 或 main 分支&#xff09;之外创建新的开发线&#xff0c;以在不干扰主线的情…

关于C#操作SQLite数据库的一些函数封装

主要功能&#xff1a;增删改查、自定义SQL执行、批量执行&#xff08;事务&#xff09;、防SQL注入、异常处理 1.NuGet中安装System.Data.SQLite 2.SQLiteHelper的封装&#xff1a; using System; using System.Collections.Generic; using System.Data.SQLite; using System.…

WebGL BabylonJs 如何切换相机

根据不同场景&#xff0c;可能会有多个相机切换的需求 &#xff0c;通过scene.activeCamera即可实现。 例如&#xff1a; // 1、创建多个相机const freeCamera new BABYLON.FreeCamera(FreeCamera,new BABYLON.Vector3(-50, -8, -16),scene,)const arcRotateCamera new BAB…

深入理解JavaScript - 箭头函数中的this永远指向全局对象?

箭头函数中的this永远指向全局对象&#xff1f; 不是&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 箭头函数并没有自己的this值&#xff0c;它捕获定义时所在上下文的this值作为自己的this值。 也就是说&#xff0c;箭头函数中的 this是在定义…

天眼护航 安全无界:天通哨兵PS02—电力巡检保护的智能利器

在电力行业中&#xff0c;输电线路的安全稳定运行对于保障社会经济活动至关重要。然而&#xff0c;广阔的输电线路常常穿越复杂的地形和恶劣的自然环境&#xff0c;给电力巡检和保护工作带来了巨大挑战。 为了提高巡检效率和响应速度&#xff0c;更好地保障电力设施的安全运行…

Opencv人机交互界面设置

Opencv人机交互界面设置 以下是一些常见的OpenCV人机交互界面设置&#xff1a; 窗口交互 显示窗口&#xff1a;可以使用cv2.imshow()函数在屏幕上显示图像。例如&#xff0c;要显示名为“image”的图像&#xff0c;可以使用以下代码&#xff1a; import cv2img cv2.imread…

前端三剑客 —— CSS (第三节)

目录 上节回顾&#xff1a; 1.CSS使用有以下几种样式; 2.选择器 1.基本选择器 2.包含选择器 3.属性选择器 [] 4.伪类选择器 &#xff1a; 5.伪元素选择器 ::before :after 3.常见样式的使用 常见样式参考表 一些特殊样式 媒体查询 自定义字体 变换效果 translate&…

深入PostgreSQL中的pg_global表空间

pg_global表空间的位置 在PG当中&#xff0c;一个实例(cluster)初始化完以后&#xff0c;你会看到有下边两个与表空间相关的目录生成&#xff1a; $PGDATA/base $PGDATA/global 我们再用元命令\db以及相关视图看看相应的表空间信息&#xff1a; postgres# \db …

雨云服务器:当清风遇上明月,服务器的美好新时代

引言&#xff1a;为什么说服务器是网站的“心脏”&#xff1f; 在数字时代&#xff0c;网站已经成为企业和个人展示自己的重要平台。然而&#xff0c;想要网站运行得稳定、快速&#xff0c;除了好的内容外&#xff0c;一个稳定、高效的服务器也是至关重要的。就像人体需要有一…

【解决】Unity Profile | FindMainCamera

开发平台&#xff1a;Unity 2020.3.7f1c1 关键词&#xff1a;FindMainCamera   问题背景 ModelViewer 是开发者基于 UnityEngine 编写的相机控制组件。ModelView.Update 中调度52次并触发3次GC.Collect。显然并不期望并尽可能避免 Update 造成的GC 问题。事实上 FindMainCame…

Qt | Qt 的重要文件简介(推荐)

一、项目文件(pro 文件)及其语法 1、项目文件(pro 文件)的作用是列举项目中的源文件, 2、pro 文件的语法形式为:“变量 操作符 值”,比如 QT += widgets,多个值之间使用空格分开。 3、pro 文件的注释:从“#”开始,直至本行结束。 4、pro 文件的操作符见下表 5、pro 文…

前台往后台传值,null到后台变成了undefined ,NaN到了后台变成了null

在前端&#xff08;如JavaScript&#xff09;和后台&#xff08;如Node.js、PHP、Java等&#xff09;之间的数据传输过程中&#xff0c;有时会遇到数据类型不一致或数据值丢失的情况。null变成undefined以及将NaN变成null可能是由以下几个原因造成的&#xff1a; 1. 数据序列化…

Ansible批量操作(上传文件、删除文件指定文件内容、执行sh文件等)

官方网站 https://www.ansible.com/ 一、Ansible 简介 1、Ansible是新出现的自动化运维工具&#xff0c;完全基于Python开发&#xff0c;集合了众多运维工具&#xff08;puppet、chef、func、fabric&#xff09;的优点&#xff0c;实现了批量系统配置、批量程序部署、批量运行…

Backend - ORM 的原生SQL

目录 一、基本认识 &#xff08;一&#xff09;意义 &#xff08;二&#xff09;原生SQL和SQL &#xff08;三&#xff09;原生SQL的执行方式 1. 直接执行自定义SQL 2. 其他方式 二、SQL 写法 &#xff08;一&#xff09;原生SQL 中的表&#xff0c;最好用双引号包裹 …

面试算法-133-区间子数组个数

题目 给你一个整数数组 nums 和两个整数&#xff1a;left 及 right 。找出 nums 中连续、非空且其中最大元素在范围 [left, right] 内的子数组&#xff0c;并返回满足条件的子数组的个数。 生成的测试用例保证结果符合 32-bit 整数范围。 示例 1&#xff1a; 输入&#xff…

随机生成Long全范围数

随机生成Long全范围数 前言实现思路主要代码分区随机生成过程案例&#xff1a;随机生成100个数 朴素的比较总结 前言 使用自带的Random.nextLong()函数生成Long型的长整数&#xff0c;范围比较小&#xff0c;如下图。100个随机数没看见10以内的数字。所以考虑实现随机化生成大…