mongodb 安装及快速操作指南

举报
tea_year 发表于 2024/02/28 22:20:04 2024/02/28
【摘要】 MongoDB和MySQL的区别数据模型不同:MySQL是关系型数据库,而MongoDB是文档型数据库。MongoDB的数据模型更加灵活,可以存储非结构化数据,适合处理大量的半结构化数据。处理大数据量:MongoDB可以处理海量数据,而MySQL在处理大数据量时可能会出现性能瓶颈。MongoDB的分布式架构可以轻松地扩展到多个节点,以处理大量数据。高可用性:MongoDB具有高可用性和容错性...


MongoDB和MySQL的区别

数据模型不同:MySQL是关系型数据库,而MongoDB是文档型数据库。MongoDB的数据模型更加灵活,可以存储非结构化数据,适合处理大量的半结构化数据。

处理大数据量:MongoDB可以处理海量数据,而MySQL在处理大数据量时可能会出现性能瓶颈。MongoDB的分布式架构可以轻松地扩展到多个节点,以处理大量数据。

高可用性:MongoDB具有高可用性和容错性,可以在多个节点之间自动分配数据,确保数据的可靠性和可用性。

适合云计算:MongoDB是云计算时代的理想选择,可以轻松地在云端部署和管理,而MySQL则需要更多的配置和管理。

适合实时应用:MongoDB支持实时数据处理和实时查询,适合于需要快速响应的实时应用场景。

MongoDB主要特征

面向文档的数据模型:MongoDB是一种文档型数据库,数据以文档的形式存储,每个文档可以包含不同的字段和值,这种数据模型比传统的关系型数据库更加灵活。

高性能:MongoDB具有高性能的读写能力,支持高并发和快速的数据查询。

分布式架构:MongoDB支持分布式架构,可以轻松地扩展到多个节点,以处理大量数据。

高可用性:MongoDB具有高可用性和容错性,可以在多个节点之间自动分配数据,确保数据的可靠性和可用性。

索引支持:MongoDB支持多种类型的索引,包括单字段索引、复合索引、全文索引等,可以提高数据查询的效率。

强大的查询语言:MongoDB支持强大的查询语言,包括聚合管道、地理空间查询、文本搜索等,可以满足不同的查询需求。

可扩展性:MongoDB可以轻松地扩展到多个节点,以处理大量数据和高并发请求。

强大的查询语言:MongoDB支持强大的查询语言,包括聚合管道、地理空间查询、文本搜索等,可以满足不同的查询需求。

可扩展性:MongoDB可以轻松地扩展到多个节点,以处理大量数据和高并发请求。

开源:MongoDB是一款开源的数据库,可以免费使用和修改。

MongoDB的缺点:

1. 不支持事务:MongoDB在早期版本中不支持事务,虽然在最新版本中已经支持了事务,但是相比传统的关系型数据库还是有所不足。

2. 内存占用较高:MongoDB在处理大量数据时,需要占用较多的内存,如果内存不足,可能会导致性能下降。

3. 数据库设计需要谨慎:MongoDB的灵活性也带来了一定的挑战,需要谨慎设计数据库结构,避免出现数据冗余和不一致的情况。

4. 存储空间占用较大:MongoDB在存储数据时,需要占用较大的存储空间,如果数据量较大,可能会导致存储成本较高。

综上所述,MongoDB具有灵活的数据模型、高性能、分布式架构、高可用性、索引支持、强大的查询语言、可扩展性和开源等优点,但是不支持事务、内存占用较高、数据库设计需要谨慎、存储空间占用较大等缺点需要注意。

何时选择MongoDB?为啥要用它?

(1)游戏场景

使用MongoDB存储游戏用户信息、装备、积分等,直接以内嵌文档的形式存储,方便查询、更新。

(2)物流场景

使用MongoDB存储订单信息、订单状态、物流信息,订单状态在运送过程中飞速迭代、以MongoDB内嵌数组的形式来存储,一次查询就能将订单所有的变更查出来,牛逼plus。

(3)社交场景

使用MongoDB存储用户信息,朋友圈信息,通过地理位置索引实现附近的人、定位功能。

(4)物联网场景

使用MongoDB存储设备信息、设备汇报的日志信息、并对这些信息进行多维度分析。

(5)视频直播

使用MongoDB存储用户信息、点赞互动信息。

MongoDB与MySQL关键字对比

mongodb 安 装 mongodb介绍



2下载mongodb


MongoDB 提供了可用于 32 位和 64 位系统的预编译二进制包,你可以从MongoDB官网下载安装。官方地址:https://www.mongodb.com/

本教程下载 3.4 版本: http://downloads.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl-v3.4- latest-signed.msi



3安装mongodb


win7系统安装mongodb需要vc++运行库,如果没有则会提示无法启动此程序,因为计算机中丢失

VCRUNTIME140.dll”

去网上下载或使用360安装:





运行 mongodb-win32-x86_64-2008plus-ssl-v3.4-latest-signed.msi



!I

Cus't o:11 Setlup

s



below to,    S WIU



······! t- J    00 1u, ss








o    bon:    r.;: "f'rogram门泛 5,


ng0oti\:)'er,,-er \:J. 4 \


I Browse. Ii



Re,set


][    Dis,k Uge



)[    Ba    


Next


    Cal'i




4 启动mongodb


创建几个文件夹具体如下:数据库路径(data目录)、日志路径(logs目录)和日志文件(mongo.log文件)


创建配置文件mongo.conf,文件内容如下:



安装 MongoDB服务

通过执行bin/mongod.exe,使用--install选项来安装服务,使用--config选项来指定之前创建的配置文件。 cmdd:\MongoDB\Server\3.4\bin



启动MongoDB服务



关闭MongoDB服务



移除MongoDB服务



启动mongodb服务,

命令执行后,浏览器中输入http://127.0.0.1:27017看到如下界面即说明启动成功



出现下图说明安装成功


也可以通过bin目录下的mongo.exe连接mongodb


5 安装studio3t


studio3tmongodb优秀的客户端工具。官方地址在https://studio3t.com/


下载studio3t


安装并启动:


创建一个新连接:



填写连接信息:

连接成功:





修改字体:

默认Studio3t的字体太小,需要修改字体: 点击菜单:Edit--->Preferences




6 mongodb入门


6.1 基础概念


mongodb中是通过数据库、集合、文档的方式来管理数据,下边是mongodb与关系数据库的一些概念对比:


SQL术语/概念

MongoDB术语/概念

解释/说明

database

database

数据库

table

collection

数据库表/集合

row

document

数据记录行/文档

column

field

数据字段/

index

index

索引

table joins


表连接(MongoDB不支持)

primary key

primary key

主键,MongoDB自动在每个集合中添加_id的主键




1、一个mongodb实例可以创建多个数据库

2、一个数据库可以创建多个集合

3、一个集合可以包括多个文档


6.2 连接mongodb


mongodb的使用方式是客户服务器模式,即使用一个客户端连接mongodb数据库(服务端)。 1、 命令格式


mongodb:// 固定前缀username:账号,可不填password:密码,可不填

host:主机名或ip地址,只有host主机名为必填项。

port:端口,可不填,默认27017

/database:连接某一个数据库

?options:连接参数,key/value例子:



2、使用mongodb自带的javascript shellmongo.exe)连接


windows版本的mongodb安装成功,在安装目录下的bin目录有mongo.exe客户端程序

cmd状态执行mongo.exe







此时就可以输入命令来操作mongodb数据库了,javascript shell可以运行javascript程序。3、使用studio3T连接

4、使用java程序连接

详细参数:http://mongodb.github.io/mongo-java-driver/3.4/driver/tutorials/connect-to-mongodb/ 添加依赖:

测试程序:

6.3 数据库


1、查询数据库

show dbs 查询全部数据库db 显 示 当 前 数 据 库 2、创建数据库

命令格式:

例子:

use test02

test02数据库则切换到此数据库,没有则创建。注意:

新创建的数据库不显示,需要至少包括一个集合。

3、删除数据库(慎用!!!) 命令格式:

例子:

删除test02数据库

先切换数据库:use test02

再执行删除:db.dropDatabase()



6.4 集合


集合相当于关系数据库中的表,一个数据库可以创建多个集合,一个集合是将相同类型的文档管理起来。


1、创建集合



2、删除集合



show collections


6.5 文档


6.5.1 插入文档

mogodb中文档的格式是json格式,下边就是一个文档,包括两个key_id主键和name

插入命令:


每个文档默认以_id作为主键,主键默认类型为ObjectId(对象类型),mongodb会自动生成主键值。 例子:


注意:同一个集合中的文档的key可以不相同!但是建议设置为相同的。


6.5.2 更新文档

命令格式:




1、替换文档

将符合条件 "name":"北京高级程序"的第一个文档替换为{"name":"北京高级程序员","age":10}



只更新一条???

2$set修改器

使用$set修改器指定要更新的keykey不存在则创建,存在则更新。 将符合条件 "name":"北京高级程序"的所有文档更新nameage的值。



multifalse表示更新第一个匹配的文档,true表示更新所有匹配的文档。



6.5.3 删除文档

命令格式:


1、删除所有文档db.student.remove({})

2、删除符合条件的文档

6.5.4 db.student.remove({"name":"高级程序"})查询文档



1、 查询全部



2、查询符合条件的记录

查询name等为"高级程序员"的文档。



3、投影查询

只显示nameage两个key_id主键不显示。




6.%2 用户


6.1.%3 创建用户

语法格式:



例子:

创建root用户,角色为root



内置角色如下:

%4. 数据库用户角色:readreadWrite;

%4. 数据库管理角色:dbAdmindbOwneruserAdmin


%4. 集群管理角色:clusterAdminclusterManagerclusterMonitorhostManager

%4. 备份恢复角色:backuprestore

%4. 所有数据库角色:readAnyDatabasereadWriteAnyDatabaseuserAdminAnyDatabase

dbAdminAnyDatabase

%4. 超级用户角色:root

db.system.users.find()

db.auth("root","111111")

6.2.%3 认证登录

为了安全需要,Mongodb要打开认证开关,即用户连接Mongodb要进行认证,其中就可以通过账号密码方式进行 认证。

1、在mongo.conf中设置 auth=true

2、重启Mongodb

3、使用账号和密码连接数据库


1) mongo.exe连接



mongo --authenticationDatabase admin -u test -p test

admin


2) Studio 3T连接


6.3.%3 查询用户

查询当前库下的所有用户:

show users



6.4.%3 删除用户

语法格式:


db.dropUser("用户名")


例子:

删除test1用户

db.dropUser("test1")

6.5.%3 修改用户

语法格式:

例子:

先创建test1用户:

修改test1用户的角色为readWriteAnyDatabase

6.6.%3 修改密码

语法格式:

例子:

修改test1用户的密码为123

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。