mongodb使用总结01-基础概念以及连接方法_md
Posted lidejie34
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mongodb使用总结01-基础概念以及连接方法_md相关的知识,希望对你有一定的参考价值。
step 1 基础概念
在mongodb中基本的概念是
数据字段/域(field)、 文档(document)、 集合(collection)、 数据库(datebase),
把这些概念和关系型数据库中的概念相互对比就会比较容易理解:
SQL术语/概念 | MongoDB术语/概念 | 解释/说明 |
---|---|---|
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据记录行/文档 |
column | field | 数据字段/域 |
primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
1. 数据库(database)
一个mongodb中可以建立多个数据库
MongoDB的单个实例可以容纳多个独立的数据库,每一个都有自己的集合和权限,不同的数据库也放置在不同的文件中。
"show dbs" 命令可以显示所有数据的列表。
> show dbs admin 0.000GB config 0.000GB local 0.000GB test 0.000GB
"use {dbname}" 命令可以切换使用的数据库 和创建新的数据库(新的数据库只有插入第一条数据的时候才会被真正创建)
> use admin switched to db admin
"db" 命令可以查看当前所在数据库
>db admin
2 集合(collection)
集合就是 MongoDB 文档组, 类似于关系型数据库中的 table
集合存在于数据库中,集合没有固定的结构下面这些全部可以存储与同一集合中
{"name":"user1"} {"name":"user2","age":18} {"age":20}
注意
- 集合名不能是空字符串""。
- 集合名不能含有 字符(空字符),这个字符表示集合名的结尾。
- 集合名不能以"system."开头,这是为系统集合保留的前缀。
- 用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为某些系统生成的集合中包含该字符。除非你要访问这种系统创建的集合,否则千万不要在名字里出现$。
capped collections
就是固定大小的collection, 单位是字节。collection 的数据存储空间值提前分配的。
注意: 指定的存储大小包含了数据库的头信息。
db.createCollection("mycoll", {capped:true, size:100000})
2文档(document)
文档是一组键值(key-value)对(即BSON), 即相当于RDBMS(关系型数据库)中的一行。
MongoDB 的文档不需要设置相同的字段,并且相同的字段不需要相同的数据类型,这与关系型数据库有很大的区别,也是 MongoDB 非常突出的特点。{"name":"user1"} {"name":"user2","age":"18"} {"name":"user3","age":20}
需要注意的是:
- 文档中的键/值对是有序的。
- 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)。
- MongoDB区分类型和大小写。
- MongoDB的文档不能有重复的键。
- 文档的键是字符串。除了少数例外情况,键可以使用任意UTF-8字符。
文档键命名规范:
- 键不能含有 (空字符)。这个字符用来表示键的结尾。
- .和$有特别的意义,只有在特定环境下才能使用。
- 以下划线"_"开头的键是保留的(不是严格要求的)。
step2 数据库连接
1.标准URI 连接(一般用于程序中访问,操作数据库)
mongodb://[username:[email protected]]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
- mongodb:// 这是固定的格式,必须要指定。
- username:[email protected] 可选项,如果设置,在连接数据库服务器之后,驱动都会尝试登陆这个数据库
- host1 必须的指定至少一个host, host1 是这个URI唯一要填写的。它指定了要连接服务器的地址。如果要连接复制集,请指定多个主机地址。
- portX 可选的指定端口,如果不填,默认为27017
- /database 如果指定username:[email protected],连接并验证登陆指定数据库。若不指定,默认打开 test 数据库。
- ?options 是连接选项。如果不使用/database,则前面需要加上/。所有连接选项都是键值对name=value,键值对之间通过&或;(分号)隔开
选项 描述 replicaSet=name 验证replica set的名称。 Impliesconnect=replicaSet. slaveOk=true|false
- true:在connect=direct模式下,驱动会连接第一台机器,即使这台服务器不是主。在connect=replicaSet模式下,驱动会发送所有的写请求到主并且把读取操作分布在其他从服务器。
- false: 在 connect=direct模式下,驱动会自动找寻主服务器. 在connect=replicaSet 模式下,驱动仅仅连接主服务器,并且所有的读写命令都连接到主服务器。
safe=true|false
- true: 在执行更新操作之后,驱动都会发送getLastError命令来确保更新成功。(还要参考 wtimeoutMS).
- false: 在每次更新之后,驱动不会发送getLastError来确保更新成功。
w=n 驱动添加 { w : n } 到getLastError命令. 应用于safe=true。 wtimeoutMS=ms 驱动添加 { wtimeout : ms } 到 getlasterror 命令. 应用于 safe=true. fsync=true|false
- true: 驱动添加 { fsync : true } 到 getlasterror 命令.应用于 safe=true.
- false: 驱动不会添加到getLastError命令中。
journal=true|false 如果设置为 true, 同步到 journal (在提交到数据库前写入到实体中). 应用于 safe=true connectTimeoutMS=ms 可以打开连接的时间。 socketTimeoutMS=ms 发送和接受sockets的时间。
2.MongoDB的可视化工具
推荐 Robomongo
Robomongo 是开源,免费的MongoDB管理工具,下载地址:Robomongo下载
注意事项 :
- mongodb 默认使用 27017 对外提供访问端口
- 编辑
/etc/mongod.conf
, mongodb默认只对本机提供访问权限, 需要其他机器访问, 需要修改 bindIp 为 其他Ip, 使用 0.0.0.0 为所有ip
# network interfaces
net:
port: 27017
bindIp: 0.0.0.0
3. mongo自带 shell
使用 mongo
命令打开命令行,即可操作数据库
mongo
以上是关于mongodb使用总结01-基础概念以及连接方法_md的主要内容,如果未能解决你的问题,请参考以下文章