MongoDB的基础使用

1. 数据集操作

进入MongoDB控制台:

# 展示数据库
show dbs

# 创建并使用数据库
use 数据库名
如:use articledb

# 删除数据库
db.dropDatabase()

注:

数据库命名规则:数据库名可以是满足以下条件的任意UTF-8字符串。

  • 不能是空字符串(“”)
  • 不得含有(空格)、、$、1、和\o(空字符)
  • 应全部小写。
  • 最多64字节

默认数据库的作用:

有一些数据库名是保留的,可以直接访问这些有特殊作用的数据库。

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

2. 集合操作(类似与表)

创建集合 :

db.createCollection("集合名称")

展示集合:

show collections
或
show tables

删除集合:

db.collection.drop()
或
db.集合名称.drop()

3. 文档操作(类似与数据)

a. 单个文档插入:

使用insert() 或 save() 方法向集合中插入文档,语法如下 :

db.集合名称.insert({"articleid":"100000","content":"今天天气真好,阳光明媚","userid":"1001","nickname":"Rose","createdatetime":new Date(),"likenum":NumberInt(10),"state":null})

b. 批量文档插入:

使用insertMany ([json数据,…])

db.集合名称.insertMany([
{"articleid":"100000","content":"今天天气真好,阳光明媚","userid":"1001","nickname":"Rose","createdatetime":new Date(),"likenum":NumberInt(10),"state":null},{"articleid":"1000000","content":"今天天气真好,阳光明媚	","userid":"1001","nickname":"Rose","createdatetime":new Date(),"likenum":NumberInt(10),"state":null}
]);

c. 查询文档:

# 查询所有
db.集合名称.find()

# 查询指定文档
db.集合名称.find({userid: "11"})

# 查询文档,只返回查询到的第一条数据
db.集合名称.findOne({userid: "11"})

# 投影查询(Projection Query):如果要查询结果返回部分字段,则需要使用投影查询(不显示所有字段,只显示指定的字段)。
# 如:查询结果只显示 _id、userid、nickname :、
db.集合名称.find({userid:"1003"},{userid:1,nickname:1})

d. 文档的更新

  • 覆盖修改:会直接覆盖掉之前的内容
db.集合名称.update({_id:"1"},{likenum:NumberInt(1001)})

注:这里会将之前id为1的内容直接替换为后面指定的这个

  • 局部修改:
db.集合名称.update({_id:"2"},{$set:{likenum:NumberInt(889)}})

注:这里只会替换掉之前文档likenum的内容

  • 批量的修改

如:更新所有用户为 1003 的用户的昵称为 凯撒大帝 。

# 默认只修改第一条数据
db.集合名称.update({userid:"1003"},{$set:{nickname:"凯撒2"}})

# 修改所有符合条件的数据
db.集合名称.update({userid:"1003"},{$set:{nickname:"凯撒大帝"}},{multi:true})
  • 列值增长的修改

如果我们想实现对某列值在原有值的基础上进行增加或减少,可以使用 $inc 运算符来实现。
需求:对3号数据的点赞数,每次递增1

db.集合名称.update({_id:"3"},{$inc:{likenum:NumberInt(1)}})

e. 删除文档

  • 删除全部文档:(慎用)
db.集合名称.remove({})
  • 删除指定文档:
db.集合名称.remove({_id:"1"})

4. 分页查询

a. 统计查询数量:

  • 统计所有记录数
db.集合名称.count()
  • 按条件统计记录数:
db.集合名称.count({userid:"1003"})

b. 分页列表查询

可以使用limit()方法来读取指定数量的数据,使用skip()方法来跳过指定数量的数据。

基本语法:

db.集合名称.find().limit(条数).skip(条数)

如:

  • 查询前3条
db.集合名称.find().limit(3)
  • 查询第4和第5条
db.集合名称.find().limit(2).skip(3)

c. 排序查询

sort() 方法对数据进行排序,sort() 方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而 -1 是用于降序排列

语法:

db.集合名称.find().sort(排序方式)

如:

  • 对userid降序排列,并对访问量进行升序排列
db.集合名称.find().sort({userid:-1,likenum:1})

注:
skip(), limilt(), sort()三个放在一起执行的时候,执行的顺序是先 sort(), 然后是 skip(),最后是显示的 limit(),和命令编写顺序无关。

5. 其他复杂条件查询

a. 正则的复杂条件查询

MongoDB的模糊查询是通过正则表达式的方式实现的。语法为:

db.collection.find({field:/正则表达式/})
或 
db.集合名称.find({字段:/正则表达式/})

如:

  • 查询评论内容包含“老六”的所有文档
db.集合名称.find({content:/老六/})
  • 查询评论的内容中以“天气”开头的
db.集合名称.find({content:/^天气/})

b. 比较查询

<, <=, >, >= 这个操作符也是很常用的

语法如下:

db.集合名称.find({ "field" : { $gt: value }}) // 大于: field > value
db.集合名称.find({ "field" : { $lt: value }}) // 小于: field < value
db.集合名称.find({ "field" : { $gte: value }}) // 大于等于: field >= value
db.集合名称.find({ "field" : { $lte: value }}) // 小于等于: field <= value
db.集合名称.find({ "field" : { $ne: value }}) // 不等于: field != value

如:

  • 查询点赞数量大于700的记录
db.集合名称.find({likenum:{$gt:NumberInt(700)}})

c. 包含查询

包含:$in操作符

不包含:$nin操作符

如:

  • 查询评论的集合中userid字段包含1003或1004的文档
db.集合名称.find({userid:{$in:["1003","1004"]}})
  • 查询评论集合中userid字段不包含1003和1004的文档
db.集合名称.find({userid:{$nin:["1003","1004"]}})

d. 条件连接查询

我们如果需要查询同时满足两个以上条件,需要使用$and操作符将条件进行关联。(相 当于SQL的and)

语法为:

$and:[ { },{ },{ } ]

如:

  • 查询评论集合中likenum大于等于700 并且小于2000的文档:
db.集合名称.find({$and:[{likenum:{$gte:NumberInt(700)}},{likenum:{$lt:NumberInt(2000)}}]})

如果两个以上条件之间是或者的关系,我们使用 操作符进行关联,与前面 and的使用方式相同

语法为:

$or:[ { },{ },{ } ]

如:

  • 查询评论集合中userid为1003,或者点赞数小于1000的文档记录
db.集合名称.find({$or:[ {userid:"1003"} ,{likenum:{$lt:1000} }]})

6. 常用命令小结

选择切换数据库:

use 数据库名

插入数据:

db.集合名称.insert({bson数据})

查询所有数据:

db.集合名称.find();

条件查询数据:

db.集合名称.find({条件})

查询符合条件的第一条记录:

db.集合名称.findOne({条件})

查询符合条件的前几条记录:

db.集合名称.find({条件}).limit(条数)

查询符合条件的跳过的记录:

db.集合名称.find({条件}).skip(条数)

修改数据:

db.集合名称.update({条件},{修改后的数据}) 
或
db.集合名称.update({条件},{$set:{要修改部分的字段:数据})

修改数据并自增某字段值:

db.集合名称.update({条件},{$inc:{自增的字段:步进值}})

删除数据:

db.集合名称.remove({条件})

统计查询:

db.集合名称.count({条件})

模糊查询:

db.集合名称.find({字段名:/正则表达式/})

条件比较运算:

db.集合名称.find({字段名:{$gt:值}})

包含查询:

db.集合名称.find({字段名:{$in:[值1,值2]}})或db.集合名称.find({字段名:{$nin:[值1,值2]}})

条件连接查询:

db.集合名称.find({$and:[{条件1},{条件2}]})或db.集合名称.find({$or:[{条件1},{条件2}]})  

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

179. 最大数(LeetCode)

文章目录 前言一、题目讲解二、算法原理三、代码编写1.仿函数写法2.lambda表达式 四、验证五.总结 前言 在本篇文章中&#xff0c;我们将会带着大家采用贪心的方法解决LeetCode中最大数这道问题&#xff01;&#xff01;&#xff01; 一、题目讲解 一组非负整数&#xff0c;包…

【面试经典 150 | 图】被围绕的区域

文章目录 写在前面Tag题目来源解题思路方法一&#xff1a;深搜方法二&#xff1a;广搜 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题涉及到的…

03.Kafka 基本使用

Kafka 提供了一系列脚本用于命令行来操作 kafka。 1 Topic 操作 1.1 创建 Topic 创建一个名为 oldersix-topic 的 topic&#xff0c;副本数设置为3&#xff0c;分区数设置为2&#xff1a; bin/kafka-topics.sh \ --create \ --zookeeper 192.168.31.162:2181 \ --replication…

ROS1快速入门学习笔记 - 07话题消息的定义与使用

目录 一、话题模型 二、自定义话题消息 1. 在功能包下创建msg目录用于存储话题文件 2. 在package.xml文件中添加功能包依赖&#xff1b; 3. 在CMakeLists.txt增加编译选项&#xff1b; 4. 完成编译 5. 配置CMakeLists.txt中的编译规则&#xff08;增加发布者和订阅者&am…

卫浴品牌商家做展示预约小程序的作用是什么

卫浴品牌类别多、普通/智能、场景化等&#xff0c;无论企业还是经销商市场门店都比较饱满&#xff0c;虽然市场需求度高&#xff0c;但同样需要商家不断拓宽销售渠道和挖掘客户价值&#xff0c;破圈增长。 线上多平台发展尤为重要&#xff0c;而小程序作为连接点&#xff0c;对…

ctf web-部分

** web基础知识 ** *一.反序列化 在PHP中&#xff0c;反序列化通常是指将序列化后的字节转换回原始的PHP对象或数据结构的过程。PHP中的序列化和反序列化通过serialize()和unserialize()函数实现。 1.序列化serialize() 序列化说通俗点就是把一个对象变成可以传输的字符串…

就业班 第三阶段(nginx) 2401--4.26 day5 nginx5 nginx https部署实战

三、HTTPS 基本原理 1、https 介绍 HTTPS&#xff08;全称&#xff1a;HyperText Transfer Protocol over Secure Socket Layer&#xff09;&#xff0c;其实 HTTPS 并不是一个新鲜协议&#xff0c;Google 很早就开始启用了&#xff0c;初衷是为了保证数据安全。 近些年&…

ArcGIS小技巧—模型构建器快速提取河网

上篇文章介绍的基于DEM的河网提取&#xff0c;需要使用多个工具&#xff0c;整体操作比较繁琐&#xff0c;在日常工作中&#xff0c;使用Arcgis提供的模型构建器可以帮助我们将多个工具整合在一起&#xff0c;在面对大量数据批量处理时&#xff0c;可以大大提高工作效率 利用模…

【题解】—— LeetCode一周小结17

【题解】—— 每日一道题目栏 上接&#xff1a;【题解】—— LeetCode一周小结16 22.组合总和 Ⅳ 题目链接&#xff1a;377. 组合总和 Ⅳ 给你一个由 不同 整数组成的数组 nums &#xff0c;和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数…

基于SSM的“个性化电子相册”的设计与实现(源码+数据库+文档+PPT)

基于SSM的“个性化电子相册”的设计与实现&#xff08;源码数据库文档PPT) 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SSM 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 个性化电子相册功能结构图 系统后台界面 会员信息管理界面 相…

在网站源码后台增加响应式布局

一本教材上的网站源码&#xff0c;后台在手机上查看还是按照电脑的页面样式&#xff0c;不方便查看和发布新内容。教材上讲了响应式布局。对于页面结构简单的网站&#xff0c;可以利用响应式&#xff0c;使页面自动适用各种屏幕的分辨率。 今天在一个网站源码的后台使用了响应…

经典案例:学习 Java 异常处理的最佳实践

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一个人虽可以走的更快&#xff0c;但一群人可以走的更远。 我是一名后…

OpenCV如何模板匹配

返回:OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇&#xff1a;OpenCV如何实现背投 下一篇 &#xff1a;OpenCV在图像中寻找轮廓 目标 在本教程中&#xff0c;您将学习如何&#xff1a; 使用 OpenCV 函数 matchTemplate()搜索图像贴片和输入图像之间…

为什么我的Mac运行速度变慢 mac运行速度慢怎么办 如何使用CleanMyMac X修复它

近些年伴随着苹果生态的蓬勃发展&#xff0c;越来越多的用户开始尝试接触Mac电脑。然而很多人上手Mac后会发现&#xff0c;它的使用逻辑与Windows存在很多不同&#xff0c;而且随着使用时间的增加&#xff0c;一些奇奇怪怪的文件也会占据有限的磁盘空间&#xff0c;进而影响使用…

电脑已经有了一个Windows10,再多装一个Windows10组成双系统

前言 前段时间已经讲过一次双Windows系统的安装教程&#xff0c;但是小白重新去看了一下&#xff0c;发现写的内容太多&#xff0c;怕小伙伴看了之后一脸萌。 所以今天咱们就重新再来讲讲&#xff1a;在同一台机器上安装Windows10双系统的教程。 注意哦&#xff01;这里的Wi…

用来传输文件的协议-FTP

一.FTP协议--文件传输协议 1.了解FTP协议 &#xff08;1&#xff09;FTP服务是用来传输文件的协议 FTP&#xff08;File Transfer Protocol&#xff0c;文件传输协议&#xff09;是TCP/IP协议组中的协议之一&#xff0c;用于互联网上的控制文件的双向传输。是传输文件到Linu…

C++:string 类

在C中定义一个 std::string 字符串可以采用以下几种方式&#xff1a; 1.使用字符串字面量初始化&#xff1a; std::string str "Hello, world!"; 2.使用构造函数初始化&#xff1a; std::string szStringB("Hello wolven"); 3.使用重复字符初始化&am…

51单片机入门(一)

1. 51单片机的基础介绍 2. RAM和ROM的区别 总体而言&#xff0c;RAM和ROM在计算机系统中起着不同的角色&#xff0c;RAM用于临时存储运行时数据&#xff0c;而ROM用于存储永久性的固件和系统程序。 3. 为什么叫51单片机 因为51系列单片机都是使用Intel 8031指令系统的单片机…

【链表——数据结构】

文章目录 1.单链表1.定义2.基本操作2.1.不带头结点2.2后插2.3前插2.4删除2.5按位查找2.6按值查找2.7求单链表长度2.8 建表 2.双链表1.初始化2.插入(后插)3.删除(后删)4.遍历 3.循环链表1.循环单链表2.循环双链表3.代码问题 4.静态链表1.简述基本操作的实现1.初始化3.删除某个结…

前端---Bootstrap---的下载和使用

目录 Bootstrap的下载 网页链接: 下载步骤: Bootstrap的使用 引用步骤: Bootstrap常用: Bootstrap-栅格系统 Bootstrap-组件 Bootstrap 是由 Twiter 公司开发维护的前端 U框架&#xff0c;它提供了大量编写好的 CSS 样式&#xff0c;允许开发者结合一定 HTML结构及JavaS…
最新文章