.NET 云原生架构师训练营(模块二 基础巩固 MongoDB 介绍和基础)--学习笔记

DotNet NB

共 1821字,需浏览 4分钟

 ·

2021-01-06 12:28

2.5.1 MongoDB -- 介绍

  • mysql vs mongo

  • 快速开始

mysql vs mongo

对比mysqlmongo
数据存储table 二维表结构,需要预先定义结构json 类文档,不需要预先定义结构。可随意新增或删除字段,新增字段不会对已存在的字段产生影响
查询语法sql (structured query language)mongo
索引如果不定义索引,则进行全表扫描如果不定义索引,则进行全表扫描
集群支持主从复制内置副本集、分片、和自动选举
场景关系型结构,在多行插入时需要事务保障实时数据分析、内容管理、iot设备、移动设备(事务需要有内置副本才可以做)
数据结构结构化、数据 schema 定义清晰未知数据结构类型
风险sql 注入攻击相对来说风险更低
分析确实需要关系型数据库来保障写入并发高,没有 DBA

快速开始

安装 mongo in docker

docker run -it --volume=/root/docker/mongo01/data:/data/db -p 27017:27017 --name mongo01 -d mongo

robt 3t 下载地址:
https://download.studio3t.com/robomongo/windows/robo3t-1.4.2-windows-x86_64-8650949.exe

新增数据库books,新增集合author

增删改查

// 插入
db.author.insertOne({"name":"mingson", "age":25})
db.author.insertOne({"name":"jesse", "age":18})
db.author.insertOne({"name":"bobo", "age":18})

// 查询
db.getCollection('author').find({"name":"mingson"})
db.getCollection('author').find({"name":{$eq:"mingson"}})

// 更新
db.author.updateOne({"name":"mingson"},{$set:{"age":20}})

// 删除
db.author.deleteOne({"name":"bobo"})

// 返回字段,1返回,0不返回
db.getCollection('author').find({"name":"mingson"},{"name":1,"_id":0})

2.5.2 MongoDB -- 基础

mongo db 文档:
https://docs.mongodb.com/manual/introduction/

中文 mongo db 手册:
https://mongoing.com/docs/tutorial/insert-documents.html

数据库/集合/文档

database/collection/document

mongomysql
databasedatabase
collectiontable
documentrow
filedcolumn

数据库

  • 数据库的名称是大小写敏感

不能包含以下字符(win):/\."$*<>:|?
不能包含以下字符(unix/linux):/\."
$
  • 不能超过64个字符

集合

  • 不能包含$

  • 不能为空,不能包含null

  • 不能以system.开头

字段名

  • 不能为空,不能包含null

  • 顶级字段不能以$开头

  • _id是保留字段名称

BosnTypes

https://mongoing.com/docs/reference/bson-types.html

stringstring
boolBoolean
intint
longlong
decimaldecimal
doubledouble
datedate
timestamptimestamp
nullnull
  • object

  • array

  • objectid

  • regex

  • javascripe

课程链接

.NET云原生架构师训练营讲什么,怎么讲,讲多久


欢迎各位读者加入微信群一起学习交流,
在公众号后台回复“加群”即可~~


浏览 40
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报