小白带你学习linux的MongoDB(三十四)

news2024/11/26 18:35:26

目录

一、概述

1、相关概念

2、特性

二、应用场景

三、安装

四、目录结构

五、默认数据库

1、admin:       

2、local:           

3、config:           

六、数据库操作

1、库操作

2、文档操作

七、MongoDB数据库备份

1、备份命令

2、回数据库删除数据

3、恢复数据


一、概述

mongodb是一个nosql数据库,它有高性能、无模式、文档型的特点。是nosql数据库中功能最丰富,最像关系数据库的。数据库格式为BSON

1、相关概念

实例:系统上运行的mongodb的进程,类似于mysql实例;

库:每个数据库都是独立的,有自己的用户,权限,独立存储集合,类似于mysql的库;

集合:由一组文档构成,类似于mysql的表;

文档:mongodb数据库的最小数据集,是由多个键值对有序组合的数据单元,类似于mysql的数据记录;

主键

 唯一标识一行数据

2、特性

1、面向集合文档存储,适合存储json形式的数据;

2、格式自由,数据格式不固定,数据结构发生变更的同时不会影响程序运行;

3、面向对象的sql查询语句,基本涵盖关系型数据库的所有查询语句;

4、有索引的支持,查询效率更快;

5、支持复制和自动故障转移;

6、可以使用分片集群提升查询性能

二、应用场景

游戏

物流

社交

物联网

视频直播

大数据

三、安装

编译安装

RPM安装

[mongodb-org-4.2]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.2/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc

cd /etc/yum.repos.d/


vim mongodb.repo

yum install -y mongodb-org

启动数据库

systemctl start mongod.service

四、目录结构

rpm -ql mongodb-org-server

/etc/mongod.conf 主配置文件
port: 27017 监听端口号
bindIp: 127.0.0.1  监听地址
/run/mongodb PID文件
/usr/bin/mongod 启动命令
/var/lib/mongo存储数据文件
/var/log/mongodb日志
rpm -ql mongodb-org-shell

 

/usr/bin/mongo                     客户端命令

rpm -ql mongodb-org-tools

/usr/bin/mongodump备份数据库
/usr/bin/mongoexport备份文档
/usr/bin/mongoimport 恢复文档
/usr/bin/mongorestore 恢复数据库

五、默认数据库

1、admin:       

从权限的角度来看,这是"root"数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。

一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器。

2、local:           

 这个数据库永远不会被复制,可以用来存储限于本地单台服务器的任意集合。

3、config:           

当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。

六、数据库操作

1、库操作

登录数据库

mongo

查看数据库

show databases

show dbs

show databases

show dbs

显示当前所在数据库

db

db

 

切换数据库

use dbName

use  dbName

数据库创建

隐式创建

不用主动创建,使用use newDB,会自动创建不存在的数据库

只有在库中创建集合后才会保存,并使用show dbs查看到

创建数据库  > db.createCollection('class')

删除数据库

use dbName

db.dropdatabase()

 

2、文档操作

查看集合         show tables

创建集合          db.createCollection("test")

删除集合           db.需要删除的集合名称.drop()

插入数据(文档)      db.集合名称.insert({key:value})

单行            db.集合名称.insertmany([{key:value},{key:value},{key:value}])

多行             mongodb默认数字的数据类型float浮点型,若要改变为整型:NumberInt(数字)

查询数据

全集合查询

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

db.集合名称.find()

条件查询

db.info.find({查询条件1key:value,查询条件2,...},{key1:1|0,key2:1|0,...})

key:1 显示,key:0 不显示

当显示的key只有一个时,key:1 只显示该key及对应value,key:0 显示除了该key之外其他所有keyvalue

当我们只想要显示密码时就需要加0 

解:

这段代码是在一个数据库名为"class1"的集合中查找所有满足条件为{'username':'ljt'}的文档。在返回结果时,只返回"password"字段的值,并且不包含"_id"字段。所以,这段代码的意思是找到所有用户名为"ljt"的文档,并返回它们的密码值。

 db.class1.find({'username':'ljt'},{'password':1,'_id':0})

查询集合中有多少文档              db.集合名称.count()

 db.class1.count()

删除数据

全文删除               db.集合名称.remove({})

 db.class.remove({})

条件删除                db.集合名称.remove({key:value})

 db.class1.remove({'san':'123'})

 

更新数据

db.info.update({_id:"3"}, {$set:{nickname:"jack"}})

所有满足条件的文档都进行更新

db.info.update({userid:"1003"},{$set:{nickname:"tom"}},{multi:true})

更新文档进行数值替换

db.info.update({userId:"1003"},{$inc:{userId:NumberInt(100)}})

创建用户的时候加一起

七、MongoDB数据库备份

1、备份命令

mongodump

选项

  • -h=hostname:port:指定MongoDB服务器的主机名和端口号。
  • -u=<username>:指定要连接到MongoDB服务器的用户名。
  • -p=<password>:指定要连接到MongoDB服务器的密码。
  • --authenticationDatabase=<dbname>:指定用于进行身份验证的数据库名称。
  • -d=<database>:指定要使用的数据库名称。
  • -o=<path>:指定输出文件的路径。

语法

mongodump -d dbName -h hostName:port -u userName -p Password -o backupDirectory

mongoexport

2、回数据库删除数据

 db.class1.deleteMany({})

 

选项

-h=hostname:port

-u=<username>

 -p=<password>

 --authenticationDatabase=<dbname>

 -d=<database>

 -o=<path>

语法

mongoexport -d dbName -c tableName -h hostName:port -u userName -p Password -o backupDirectory/jsonFile.json

恢复命令

mongorestore

选项

-h=hostname:port

-u=<username>

-p=<password>

 --authenticationDatabase=<dbname>

 -d=<database>

 --drop 当目标数据库中存在同名集合则删除再恢复

语法

mongorestore -h hostName -u username -p password -d dbName -c tableName bakcupDirector/bsonFile

mongoimport

3、恢复数据

进入库里查看数据

 

 

选项

-h=hostname:port

-u=<username>

 -p=<password>

--authenticationDatabase=<dbname>

-d=<database>

--drop 当目标数据库中存在同名集合则删除再恢复

语法

mongoimport -d dbName -c tableName -h hostName:port -u userName -p Password  backupDirectory/jsonFile.json

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

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

相关文章

数据库内日期类型数据大于小于条件查找注意事项

只传date格式的日期取查datetime的字段的话默认是 00:00:00 日期类型字符串需要使用 ’ ’ 单引号括住 使用大于小于条件查询某一天的日期数据 前后判断条件不能是同一天 一个例子 数据库内数据&#xff1a; 查询2023-08-14之后的数据&#xff1a; select * from tetst…

Linux 内核第一版 (v0.01) 开源代码解读

探索Linux v0.01的内部结构&#xff0c;Linux内核经常被认为是一个庞大的开源软件。在撰写本文时&#xff0c;最新版本是v6.5-rc5&#xff0c;包含36M行代码。不用说&#xff0c;Linux是几十年来许多贡献者辛勤工作的成果。 Linux 内核首个开源版本 (v0.01) 的体积非常小&…

HBuilderX

HX 简介下载安装 简介 HBuilderX 是一款由 DCloud 开发的集成开发环境 (IDE)&#xff0c;主要用于前端开发和移动应用开发。它基于 Visual Studio Code 平台&#xff0c;针对 Web 开发、小程序开发、移动端开发等提供了丰富的功能和插件。 DCloud官网: https://www.dcloud.io …

剑指offer57-II.和为s的连续正数序列

看完题脑子里闪过了暴力法&#xff0c;就是从1开始往后累加&#xff0c;直到累加和等于或大于target&#xff0c;如果等于就放进数组&#xff0c;如果大于就从2开始加&#xff0c;但是这种想法只是闪过一下&#xff0c;因为我觉得加上填充数组需要3层循环肯定会超时&#xff0c…

java毕业设计-智慧食堂管理系统-内容快览

首页 智慧食堂管理系统是一种可以提高食堂运营效率的管理系统。它将前端代码使用Vue实现&#xff0c;后端使用Spring Boot实现。这个系统的目的是简化食堂管理&#xff0c;提高食堂服务质量。在现代快节奏的生活中&#xff0c;人们对餐饮服务提出了更高的要求&#xff0c;食堂管…

Spring Boot实现第一次启动时自动初始化数据库流程详解

随着互联网的发展项目中的业务功能越来越复杂&#xff0c;有一些基础服务我们不可避免的会去调用一些第三方的接口或者公司内其他项目中提供的服务&#xff0c;但是远程服务的健壮性和网络稳定性都是不可控因素。 在测试阶段可能没有什么异常情况&#xff0c;但上线后可能会出…

一文详解Apipost数据模型功能

在Apipost数据模型中用户可以预先创建多个数据模型&#xff0c;并在API设计过程中重复利用这些模型来构建API 创建数据模型 在左侧导航点击「数据模型」-「新建数据模型」在右侧工作台配置数据模型参数 引入数据模型 在API设计预定义响应期望下点击引用数据模型&#xff0c;…

实录分享 | 使用Prometheus和Grafana监控Alluxio运行状况

欢迎来到【微直播间】&#xff0c;2min纵览大咖观点 本次分享主要包括三个方面&#xff1a; Prometheus&Grafana简介环境搭建手动调优 一、 Prometheus&Grafana简介关于Prometheus&#xff1a; Prometheus 是一个开源的完整监控解决方案&#xff0c;其对传统监控系…

[SpringBoot3]访问数据库

四、访问数据库 SpringBoot框架为SQL数据库提供了广泛的支持&#xff0c;既有用JdbcTemplate直接访问JDBC同时支持“object relational mapping”技术&#xff08;如MyBtais、Hibernate&#xff09;。SpringData独立的项目提供对多种关系型和非关系型数据库的访问支持&#xf…

【Vue-Router】命名视图

命名视图 同时 (同级) 展示多个视图&#xff0c;而不是嵌套展示&#xff0c;例如创建一个布局&#xff0c;有 sidebar (侧导航) 和 main (主内容) 两个视图&#xff0c;这个时候命名视图就派上用场了。 可以在界面中拥有多个单独命名的视图&#xff0c;而不是只有一个单独的出…

【Maven】SpringBoot项目使用maven-assembly-plugin插件多环境打包

SpringBoot项目使用maven-assembly-plugin插件多环境打包 1.创建SpringBoot项目并在pom.xml文件中添加maven-assembly-plugin配置 <!-- 多环境配置 --><profiles><!-- 开发环境 --><profile><id>dev</id><properties><prof…

Leaflet入门,Leaflet加载xyz地图,以vue-leaflet插件加载高德地图为例

前言 本章介绍Leaflet使用vue2-leaflet或者vue-leaflet插件方式便捷加载xyz高德地图。 # 效果演示 vue如何使用Leaflet vue2如何使用:《Leaflet入门,如何使用vue2-leaflet实现vue2双向绑定式的使用Leaflet地图,以及初始化后拿到leaflet对象,方便调用leaflet的api》 vue3…

代码随想录算法训练营之JAVA|第二十九天|1005. K 次取反后最大化的数组和

今天是第29天刷leetcode&#xff0c;立个flag&#xff0c;打卡60天。 算法挑战链接 1005. K 次取反后最大化的数组和https://leetcode.cn/problems/maximize-sum-of-array-after-k-negations/ 第一想法 题目理解&#xff1a;数组在进行K次取反后&#xff0c;求累加的最大值。…

Rust 复数运算,重载加减乘除运算

复数 基本概念 复数定义 由实数部分和虚数部分所组成的数&#xff0c;形如a&#xff0b;bi 。 其中a、b为实数&#xff0c;i 为“虚数单位”&#xff0c;i 的平方等于&#xff0d;1。 a、b分别叫做复数a&#xff0b;bi的实部和虚部。 当b&#xff1d;0时&#xff0c;a&am…

安世收购英国最大晶圆制造厂

据英国《泰晤士报》报道&#xff0c;英国Newport晶圆厂的员工 给 《 泰晤士报 》 的一封措辞强硬的信中&#xff0c;表 示 代表582名员工的员工协会表示。Newport晶圆厂员工们完全支持Nexperi a安世半导体 对工厂的所有权。因为Nexperia提供 了稳定的工作、改善了工作保障、工资…

VBA 学习笔记1 对象以及属性

目录 1 取得VBA对象1.1 取得工作簿对象1.2 取得工作表对象1.3 取得单元格对象1.4 取得对象的属性1.5 文档的方法1 进入vba 界面 方式之一&#xff1a; 快捷键&#xff1a;ALTERF11 运行方式之一&#xff1a; 进入vba界面&#xff0c;点击绿色三角符号 1 取得VBA对象 1.1 取得…

Win10基于 Anaconda 配置 Deeplabcut 环境

最近需要做动物行为学分析的相关研究&#xff0c;同时由于合作者只有 Windows 系统&#xff0c;于是只好在 Windows 中配置环境。说实话还真的是挺折磨的。。。 一、下载 Anaconda 可以通过清华源下载 Anaconda&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/anaconda/ar…

leetcode剑指 Offer 58 - II. 左旋转字符串(两种方法)

题目&#xff1a;leetcode剑指 Offer 58 - II. 左旋转字符串 描述&#xff1a; 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如&#xff0c;输入字符串"abcdefg"和数字2&#xff0c;该函数将返回…

Gradle依赖管理:编译时和运行时依赖的区别

&#x1f337;&#x1f341; 博主猫头虎 带您 Go to New World.✨&#x1f341; &#x1f984; 博客首页——猫头虎的博客&#x1f390; &#x1f433;《面试题大全专栏》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &a…

nsq中diskqueue详解 - 第一篇

一、diskqueue是什么&#xff0c;为什么需要它 在nsq中消息主要存在于两种队列 一种是内存队列&#xff0c;内部是用go的通道实现&#xff0c;所以处理速度很快&#xff0c;缺点是一旦nsqd进程挂掉消息就丢失了&#xff0c;这让人难以接受&#xff0c;数据丢了不得被用户骂死…