面试题--MongoDB

MongoDb

MongoDB 是什么?

mongodb 是属于文档型的非关系型数据库,是开源、高性能、高可用、可扩展的
数据逻辑层次关系:文档=>集合=>数据库
在关系型数据库中每一行的数据对应 mongodb 里是一个文档。mongodb 的文档
是以 BSON(binary json)格式存储的,其格式就是 json 格式。

1>集合

集合是一组文档(即上面的 users 集合)。集合相当于关系数据库中的表,但集合
中的文档长度可不同(集合中的文档中的键值对个数可不同)、集合中文档的 key 可不同。
向集合中插入第一个文档时,集合会被自动创建。

2>文档

文档是一组键值对,用{ }表示,字段之间用逗号分隔。相当于关系数据库中的一行
(一条记录)。示例:一个文档

3>字段

即一个键值对,key 必须是 String 类型,value 可以是任意类型。

MongoDB 和关系型数据库 mysql 区别

上图中,左边的是 MySQL 数据库中 users 表,右边是 MongoDB 中 users 集合。虽
然表现形式不同,但是数据内容还是一样的。其中:
test:表示数据库
users:表示集合,类似 MySQL 中的表
{id:"1",name:"张三",age:28,email:"zhangs@gmail.com"}:表示一个文档,类似于
MySQL 中的记录
id、name、age 和 email:表示字段

MongoDB 有 3 个数据库

一个 MongoDB 中可以建立多个数据库,这些数据库是相互独立的,有自己的集合和权
限。不同的数据库使用不同的文件存储(不存储在一个文件中)。
MongoDB 默认有 3 个数据库:
admin: 从权限的角度来看,这是"root"数据库。将一个用户添加到这个数据库,这个
用户会自动继承所有数据库的权限。一些特定的服务器端命令也只能在这个数据库中运行,
比如列出所有的数据库或者关闭服务器。
local: 这个数据库永远不会被复制,里面的数据都是本地的(不会复制到其他 MongoDB
服务器上),可以用来存储限于本地单台服务器的任意集合
config: 当 Mongo 用于分片设置时,config 数据库在内部使用,用于保存分片的相关信
息。

Mongo 中的数据类型

  1. null
  2. false 和 true
  3. 数值
  4. UTF-8 字符串
  5. 日期 new Date()
  6. 正则表达式
  7. 数组
  8. 嵌套文档
    99 9. 对象 ID ObjectId()
  9. 二进制数据
  10. 代码
相关推荐
即将进化成人机3 分钟前
springboot项目创建方式
java·spring boot·后端
我科绝伦(Huanhuan Zhou)7 分钟前
Oracle控制文件、SCN与检查点机制深度解析及数据库初始化原理
运维·数据库·oracle
教练、我想打篮球11 分钟前
117 javaweb servlet+jsp 项目中修改了 数据库连接配置, 却怎么都不生效
java·servlet·jdbc·jsp
你不是我我14 分钟前
【Java 开发日记】我们来说一说 Redis IO 多路复用模型
java·开发语言·redis
SadSunset16 分钟前
(13)复杂查询
java·笔记·架构·mybatis
浩瀚地学16 分钟前
【Java】ArrayList
java·开发语言·经验分享·笔记
cui_win18 分钟前
MySQL max_connections连接数配置没生效,最终靠改这个参数解决
数据库·mysql
爱吃面条的猿22 分钟前
DBeaver 全能数据库管理工具的使用配置
数据库·dbeaver
阿杰同学24 分钟前
Java 设计模式 面试题及答案整理,最新面试题
java·开发语言·设计模式
这样の我25 分钟前
java 模拟chrome指纹 处理tls extension顺序
java·开发语言·chrome