MongonDB中数据库,集合,文档三者的区简单介绍(二)

版权声明:如需转载,请写明出处 https://blog.csdn.net/weixin_43113679/article/details/91348673

客户端连接

盘符:\MongoDB\Server\4.0\bin>mongo

数据库

MongoDBMySQL一样,可以建立多个数据库,不同的数据库里可以放置不同的文件,
MongoDB里的集合就是MySQL里的表,用可视化工具MongoDB Compass可以把集合转换成table
MongoDB的默认数据库为"db",该数据库存储在data目录里,

1、查看所有的数据库

> show dbs
admin   0.000GB
config  0.000GB
local   0.000GB
test    0.000GB
user    0.000GB

2、查看当前的数据库

> db
test

3、use命令连接到指定数据库

> use admin
switched to db admin
> db
admin

这个不是改变默认数据库,只是db链接到了另一个数据库,重新登录默认的数据库还是原来的
数据库的命名规则

  • 不能是空字符串("")。
  • 不得含有’ '(空格)、.、$、/、\和\0 (空字符)。
  • 应全部小写。
  • 最多64字节。(字符编码是UTF-8)

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

  • admin:在Linux中想root数据库,在windows中管理员数据库,将用户添加进去,就有了root权限或者管理员权限(是最高的)
  • local:这个数据永远不会被复制,可以用来存储于本地单台服务器的任意集合
  • config:看着名就像配置信息,当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。

集合(和MySQL里的表示一样的)

集合就是 MongoDB 文档组,类似于 RDBMS (关系数据库管理系统:Relational Database Management System)中的表格。
 集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据,但通常情况下我们插入集合的数据都会有一定的关联性。
 比如,我们可以将以下不同数据结构的文档插入到集合中:

{"site":"www.baidu.com"}
{"site":"www.google.com","name":"Google"}
{"site":"www.runoob.com","name":"菜鸟教程","num":5}

在这里插入图片描述
上面的如果没有此字段就会为No field;是动态添加字段和删除字段,如果此字段都为No field,就会删除此字段,把上面新添加的三个文档删除,集合就变成下面这样了
在这里插入图片描述
当第一个文档插入时,集合就会被创建。,用可视化工具在没有集合时,是没办法添加文档的,下面试试用命令行的模式

> use user  //链接到user数据库
switched to db user
> db     //当前数据库
user
> db.col.insert({title:"命令行插入文档"})     //插入文档  后面的博客会解释
WriteResult({ "nInserted" : 1 })
> db.col.find().pretty() //  查询当前数据库的指定文档的内容
{ "_id" : ObjectId("5cfca886e03e0fe5bf2fe391"), "title" : "命令行插入文档" }

用命令行的方式可以在数据库没有此集合时,插入文档时会新添加一个集合

集合名的命名规范

  1. 集合名不能是空字符串""。
  2. 集合名不能含有\0字符(空字符),这个字符表示集合名的结尾。
  3. 集合名不能以"system."开头,这是为系统集合保留的前缀。
  4. 用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为某些系统生成的集合中包含该字符。除非你要访问这种系统创建的集合,否则千万不要在名字里出现$。

文档(在MySQL中相当于行,就是一行数据)

文档是一组键值(key-value)对(即BSON)。MongoDB 的文档不需要设置相同的字段,并且相同的字段不需要相同的数据类型,这与关系型数据库有很大的区别,也是 MongoDB 非常突出的特点。
一个简单文档例子例子

{"site":"www.runoob.com", "name":"菜鸟教程"}

在这里插入图片描述
_idMongoDB生成的,不用自己设

下表列出了 RDBMSMongoDB 对应的术语:

RDBMS MongoDB
数据库 数据库
表格 表格
文档
字段
表联合 嵌入文档
主键 主键 (MongoDB 提供了 key 为 _id )
数据库服务和客户端
Mysqld/Oracle mongod
mysql/sqlplus mongo

需要注意的是

  1. 文档中的键/值对是有序的。
  2. 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)。
  3. MongoDB区分类型和大小写。
  4. MongoDB的文档不能有重复的键。
  5. 文档的键是字符串。除了少数例外情况,键可以使用任意UTF-8字符。

文档键命名规范:

  • 键不能含有\0 (空字符)。这个字符用来表示键的结尾。
  • .和$有特别的意义,只有在特定环境下才能使用。
  • 以下划线"_"开头的键是保留的(不是严格要求的)。

猜你喜欢

转载自blog.csdn.net/weixin_43113679/article/details/91348673
今日推荐