MongoDB(二)基础操作 创建、删除,查询等

mongodb有一个特点,如果某个库,库下面没数据(mongodb成集合),该库等于不存在的
mongodb只要创建一个库,在库下写入数据,该库才会生成

mongoshe [-h=host -p=xxx]
在这里插入图片描述

创建数据库

use 数据库名 # 如果数据库名已经存在,则表示切换到这个数据库,如果没有,则创建,但不是持久化到磁盘,
查看有权限查看的所有数据库
show dbs 或 show databases
在Mongodb中,集合只有在内容插入后才会创建。

删除数据库

use 数据库
db.dropDatabase() #db 就代表当前的数据库对象,主要用来删除已经持久化的数据库

自动的数据库 admin 、 local 、config

在这里插入图片描述

  1. admin:从权限的角度来看,这是“root”数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器
  2. local:这个数据永远不好被复制,可以用来存储限于本地单台服务器的任意集合
  3. config:当Mongo用于分片设置时,config数据库在内部使用,用来保存分片的相关信息。
创建集合 即 关系型数据库中的表

显示创建集合

use 数据库
db.createCollection(‘集合名称’)
查看集合
show collections
删除集合
db.集合名称.drop()
在这里插入图片描述

隐藏创建集合

插入文档时,同时创建结合
db.集合名.insert({})
在这里插入图片描述

文档的插入

单个文档插入

db.集合名.insert({})
在这里插入图片描述
在这里插入图片描述

批量文档插入

db.集合名.insertmany([{},{}])

在这里插入图片描述
捕获异常

try {
db.集合.insertMany([{},{}])
}catch(e){
print(e)
}

文档的查询

查询集合所有的信息
db.集合名.find()
查询集合指定的信息
db,集合名.find({})
在这里插入图片描述
查询集合中符合条件的一个记录
do.集合名.findOne() 或 db.集合.findOne({“xxx”::“vvvv”})
在这里插入图片描述

投影查询

db.集合.find({“key”:”val“},{”col1“:1})
第一个{},是查询的条件,跟sql中 where 作用一样
第二个{},是查询要显示的字段,1表示显示,0表示不显示
在这里插入图片描述

正则表达查询

db.集合.find({field:/正则/})
在这里插入图片描述

文档更新

在这里插入图片描述
覆盖修改

db.document.update({“key”:“vvv”},{“col1”:“vvv”});
在这里插入图片描述
实现对某列值在原有值的基础上进行增加或减少,可以使用$inc运算符来实现。

在这里插入图片描述
批量修改

如不加第三个参数,可以只更新符合条件的第一条记录。
db.documnet.update({“key”,“vvv”},{$set:{“key”:“vvv”}},{multi:true})
在这里插入图片描述

删除文档

db.document.remove(条件)

删除全部数据

db.document.remove({})

按条件删除

db.document.remove({“key”:“xxx”})

统计查询

db.document.count(条件)

统计文档(表)一共多行记录

db.document.count()

统计指定条件,一共多行记录

db.document.count({“key”:“xxx”});
在这里插入图片描述

分页查询

db.document.find().limit(mun).skip(num)

limit 取几条记录

skip 跳过几条记录

#取前面5条记录
db.document.find().limit(5);
#从第六条开始取所有数据
db.document.find().skip(5); 前面N不要获取

在这里插入图片描述

排序查询

$gt >
$lt <
$gte >=
$lte <=
KaTeX parse error: Expected '}', got 'EOF' at end of input: …t.find({"key":{gt:value}});
在这里插入图片描述
等于
db.document.find({“key”:“vvv”})

排序查询

key:1 asc, key:-1 desc
db.document.find().sort({key:1})
在这里插入图片描述

包含查询

KaTeX parse error: Expected '}', got 'EOF' at end of input: …t.find({"key":{in:[‘v’,‘v2’]}})
KaTeX parse error: Expected '}', got 'EOF' at end of input: …t.find({"key":{nin:[‘v’,‘vv’]}})
在这里插入图片描述

条件查询 and or

db.document.find( { KaTeX parse error: Expected 'EOF', got '}' at position 21: …[ { } , { } ] }̲ ) db.info1.fi…and:[{age:{KaTeX parse error: Expected 'EOF', got '}' at position 6: gt:30}̲},{age:{lt:40}}]})
在这里插入图片描述

在这里插入图片描述
db.document.find( {$or:[ { } , { } ] } )

总结

在这里插入图片描述

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

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

相关文章

Android - Monkey 测试应用出现Crash报错IllegalStateException

问题描述 平时使用Lottie动画都是正常的&#xff0c;没出过这个crash问题&#xff0c;看下的报错信息&#xff0c;代码中文件夹也设置了&#xff0c;没看出来问题。 AndroidRuntime: java.lang.IllegalStateException: You must set an images folder before loading an imag…

c语言常见字符函数、内存函数(详讲)

前言&#xff1a; 其实在c语言当中是没有字符串这一概念的&#xff0c;不像c里面有string类型用来存放字符串。在c语言中我们只能把字符串放在字符串常量以及字符数组中。 1.常见字符串函数 1.1strlen size_t strlen ( const char * str );作用&#xff1a;用来求字符串中 …

C语言 L1-016 查验身份证

L1-016 查验身份证 一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下&#xff1a; 首先对前17位数字加权求和&#xff0c;权重分配为&#xff1a;{7&#xff0c;9&#xff0c;10&#xff0c;5&#xff0c;8&#xff0c;4&#xff0c…

【MySQL】基础实战篇(1)—数据库与数据表的操作

创建管理数据库创建数据库查看与选择数据库修改数据库删除数据库 创建管理数据表创建数据表查看数据修改数据表删除数据表 创建管理数据库 创建数据库 语法&#xff1a; CREATE DATABASE 数据库名称;注&#xff1a; 在同一个数据库服务器上必须是唯一的&#xff0c;不允许存…

c++模版元编程,基于递归的编程

基于递归的模版元编程允许在模版中进行递归调用&#xff0c;以便在编译时生成更复杂的代码。这种技术的核心思想是将问题分解为一个个较小的子问题&#xff0c;并通过递归地调用模版来处理它们。 模版元编程的基本概念和原理&#xff1a; 模版元编程是一种利用C模版系统在编译时…

人工智能的未来:从 Jetson 到 GPT,沙龙见闻与洞察

前言 在当今数字化时代&#xff0c;人工智能正以惊人的速度改变着我们的生活和工作方式。从智能语音助手到自动驾驶汽车&#xff0c;从智能家居到医疗诊断&#xff0c;人工智能技术已经广泛渗透到各个行业&#xff0c;并为其带来了巨大的变革和创新。越来越多的行业专家、学者…

postman发送图片

POSTMAN 如何发送携带图片的请求? 闲话不叙 步骤如下&#xff1a; 新建一个请求&#xff0c;在Headers中添加一对k-v : Content-Type > multipart/form-data 请求的接口: RequestMapping("/fileUploadController")public String fileUpload(MultipartFile fil…

【C++】构造函数和析构函数第一部分(构造函数和析构函数的作用)--- 2023.9.25

目录 前言初始化和清理的概念构造函数和析构函数的作用构造函数的作用析构函数的作用 使用构造函数和析构函数的注意事项默认的构造函数和析构函数结束语 前言 在使用c语言开发的项目场景中&#xff0c;我们往往会遇到申请空间的需求&#xff0c;同时也肯定遇到过程序运行一段…

蓝牙核心规范(V5.4)10.9-BLE 入门笔记之GAP

1.概述 蓝牙核心规范的通用访问配置文件(GAP)部分定义了与设备发现和在两个设备之间建立连接有关的过程。如何执行数据的基本无连接通信、如何使用周期性广播(参见 PADVB-LE Periodic Advertising Broadcast)以及如何设置等时通信(参见 LE BIS和LE CIS - Isochronous Com…

购物车案例

1功能模块分析 请求动态渲染购物车&#xff0c;数据存vuex 数据框控件 修改数据 动态计算总价和总数量 2脚手架新建项目 终端安装axios&#xff1a;npm install axios -g 基于json-server工具&#xff0c;准备后端接口服务环境:&#xff08;模拟后台假数据&#xff09; 1…

积跬步致千里 || 可视化动图展示

可视化动图展示 目前只能在 jupyter notebook 中测试成功 %matplotlib notebook import numpy as np import matplotlib.pyplot as plt import timen 500 data np.random.normal(0,1,n)fig plt.figure() ax fig.add_subplot(111)fig.show() fig.canvas.draw()for i in ra…

互联网摸鱼日报(2023-09-25)

互联网摸鱼日报(2023-09-25) 36氪新闻 WPS AI开放邀请体验&#xff0c;打工人办公的最强福音来了 万亿早餐赛道&#xff0c;谁能笑到最后&#xff1f; 所谓能力问题&#xff0c;80%都是态度问题 本周双碳大事&#xff1a;首批CCER方法学或开放四类项目&#xff1b;隆基绿能…

什么是Redux?它的核心概念有哪些?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 什么是Redux&#xff1f;⭐ 它的核心概念有哪些&#xff1f;⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发…

C++——模板

目录 泛型编程 函数模板 函数模板概念 函数模板格式 类模板 类模板的定义格式 类模板的实例化 泛型编程 泛型编程是什么呢&#xff1f;泛型编程&#xff1a;编写与类型无关的通用代码&#xff0c;是代码复用的一种手段。模板是泛型编程的基础。型就是类型&#xff0c;不…

【Java】医院智能导诊小程序源码,springboot框架

智能导诊 可以根据用户症状描述精准推荐科室及医生智能学习医院历史数据及自动进行科室对照,与医院的系统连接后,患者可直接完成预约。 一、系统概述 “智能导诊”以人工智能手段为依托&#xff0c;为人们提供智能分诊、问病信息等服务&#xff0c;在一定程度上满足了人们自我…

低照度增强算法(图像增强+目标检测+代码)

本文介绍 在增强低光图像时&#xff0c;许多深度学习算法基于Retinex理论。然而&#xff0c;Retinex模型并没有考虑到暗部隐藏的损坏或者由光照过程引入的影响。此外&#xff0c;这些方法通常需要繁琐的多阶段训练流程&#xff0c;并依赖于卷积神经网络&#xff0c;在捕捉长距…

python+vue驾校驾驶理论考试模拟系统

管理员的主要功能有&#xff1a; 1.管理员输入账户登陆后台 2.个人中心&#xff1a;管理员修改密码和账户信息 3.用户管理&#xff1a;管理员可以对用户信息进行添加&#xff0c;修改&#xff0c;删除&#xff0c;查询 4.添加选择题&#xff1a;管理员可以添加选择题目&#xf…

ElementUI首页导航和左侧菜单静态页面的实现,以及Mockjs和总线的介绍

目录 前言 一. Mock.js 1.1 什么是Mock.js 1.2 Mockjs的安装与配置 1.2.1 安装Mock.js 1.2.2 引入Mock.js 1.3 Mockjs的使用 1.3.1 定义数据测试文件 1.3.2 mock拦截ajax请求 二. 首页导航以及左侧菜单的搭建 2.1 什么是总线 2.2 创建三个vue组件 首页AppMain.vue组…

QT 6.5下载安装及配置教程

一、下载 今天打算换一个QT安装版本,去官网看了一眼发现变成了在线安装。 本来官方下载的就慢,现在更是雪上加霜,现在给大家推荐几种下载方式。 1、国内镜像 中国科学技术大学&#xff1a;http://mirrors.ustc.edu.cn/qtproject/ 清华大学&#xff1a;https://mirrors.tuna.ts…

Ubuntu部署nginx

一、 下载nginx相关依赖包 apt-get install gccapt-get install libpcre3 libpcre3-devapt-get install zlib1g zlib1g-devsudo apt-get install opensslsudo apt-get install libssl-dev二、新建nginx的安装目录 cd /optmkdir nginxcd nginx三、通过wget下载nginx安装包 wg…