首页 > 代码库 > mongodb简介

mongodb简介

mongodb简介

转自: http://www.toutiao.com/i6398793915851342337/

一、MongoDB文档,集合,数据库的概念:

1.基本概念:

1)Document文档是MongoDB中数据的基本单元,是MongoDB的核心概念,很类似关系数据库中的行Row

2)Collection集合可以被看作没有模式的表Table

3)Database/dbs MongoDB每个实例都可容纳多个独立数据库,每个数据库都有自己的集合和权限

2.文档Document:

1)多个键及其关联的值有序地放置在一起就是文档

2)单键值文档:{“username”:”bbs11”}

3)多键值文档:{“_id”:”76b606a9f9b770517ca4d98b”,”userName”:”bbs59”,”acctAttr”:null}

4)文档中键/值对有序的

5)文档中的值不仅可以是字符串,也可以是其他数据类型(或者嵌入其他文档,数据类型部分详细讲解)

6)键是字符串,键可以使用任意UTF-8字符

7)键不能含有\0(空字符),空字符表示键的结尾

8)和$作为保留字符,通常不应出现在键中

9)以下划线”_”开头的键通常情况下是保留的(_id)

10)MongoDB不但区分数据类型,也区分大小写

{“user”:”11”}与{“user”:11}不同,{“User”:”11”}与{“user”:11”},oracle默认是不区分大小写,也可以配置区分

11)文档中不允许有重复的键:{“userName”:”bbs11”,”userName”:”david”}非法

3.集合Collention:

1)集合就是一组文档,与关系型数据库的表可类比

2)集合是无模式的,MongoDB对模式不做强制要求,由开发者灵活把握

命令规则:

3)集合名不能是空串””;

4)不能含有空字符\0;

5)不能以”system.”开头,这是系统集合保留的前缀

6)集合名不能含保留字符$;

7)组织集合的一种惯例是以.分开,近命名空间划分子集合,例如

> show collections

system.users.system.indexes(admin)

4.数据库dbs/database:

1)多个集合组成数据库

2)一个MongoDB实例可承载多个数据库,互相之间彼此独立

3)开发通常将一个应用的所有数据存放到同一个数据库中

4)磁盘中,MongoDB将不同数据库存放在不同文件中

5)命名规则:

1.数据库名是UTF-8字符串,最长64个字符

2.不能是空字符串” ”;

3.不能含’’号和.号和$号和\号和\0号

4.应全部小写

***一个MongoDB实例可承载多个数据库***:

新建data/db2

重新启动MongoDB:bin/monod --dbpath=../data/db2 --port 27018

Web端口:28018

启动shell:bin/mongo --port 27018

6)系统保留数据库

7)admin:这是root数据库,添加用户到该数据库中,该用户会自动继承所有数据库权限

8)local:这个数据库中的数据永远不会被复制,可以用于存储限于本地数据单台服务器的任意集合

9)config:分片时,config数据库在内部使用,保存分片信息(config数据就保存分片的信息,就相当于配置服务器)

10)把数据库名放集合名前,得到的就是集合的完全限定名称,叫命令空间。命令空间长度不能超过121字节,实际使用时应小于100字节

***完全限定名称***

>bbs.account --完全限定名

 

二、MongoDB shell详解

1.mongodb自带shell工具的(mongo)

1)shell使用及常用命令

2)mongodb数据工具(包括导入导出)

shell使用常用命令:

./mongo --port 27017

show dbs ---已有数据库列表

show collections ---已有集合列表

show users ---已有用户列表

use dbname ---切换数据库,系统自动延迟创建该数据库

db.account.save({‘name‘:‘test‘,‘addr‘:‘china‘}) --创建集合

db.account.find()---查看集合数据

db.dropDatabase() ---删除数据库(当前)

db.account.drop() --删除当前数据集合

启动shell(默认链接端口是27017):

[root@hadoop-senior01 bin]# ./mongo

或者

[root@hadoop-senior01 bin]# ./mongo --port 27017

查看数据库:

> show dbs

admin 0.000GB

local 0.000GB

> help

也可以切换当前不存在的数据库(动态的创建,延迟性加载,和关系型数据库不一样):

> use sb

switched to db sb

> show collections

> db.account.save({‘name‘:‘test‘,‘addr‘:‘china‘})

WriteResult({ "nInserted" : 1 })

> show collections

account

> show dbs

admin 0.000GB

local 0.000GB

sb 0.000GB

> db.account.find()

{ "_id" : ObjectId("58c724c5290846e2f0647206"), "name" : "test", "addr" : "china" }

mongodb根据算法自动分配id,也可以自定义,通常使用自定义算法

删除数据集合:

> db.account.drop()

true

删除当前数据:

> db.dropDatabase()

{ "dropped" : "sb", "ok" : 1 }

> show dbs

admin 0.000GB

local 0.000GB

2.MongDB数据工具

数据库组件:mongod,mongos(分片的时候采用),mongo

数据库工具

mongodump -h dbhost -d dbname -o dbdirectory --数据库备份

mongorestore -h dbhost -d dbname --dir dbdirectory --数据库恢复

./bsondump dump/bbs/account.bson --查看bson对象

./mongoexport -d bbs -c account -q {} -f name,addr --csv >account.csv --数据导出工具,导出为csv格式

./mongoexport -d bbs -c account -q {} -f name,addr>account.json导出为json格式

./mongoexport -d bbs -c account -q ‘{“name”:”test2”}’ -f name,addr -csv>account.csv带查询条件导出

./mongoimport -d ssb -c account --type csv --headerline --drop <mydata/account.csv--数据导入工具,导入csv文件

./mongoimport -d bbs -c account --type json --drop<account.json --导入json文件

 

mongodb简介