MongoDB由C++语言编写,运行稳定,性能高
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。
MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。(实为Bson形式)
特点:
模式自由 :可以把不同结构的文档存储在同一个数据库里
面向集合的存储:适合存储 JSON风格文件的形式
完整的索引支持:对任何属性可索引
MongoDB文档类似于JSON对象,字段值可以包含其他文档、数组、文档数组
MongoDB中的三要素:
数据库是一个集合的物理容器
集合就是关系数据库中的表
文档对应着关系数据库中的行
数据库的限制
1.不能是空字符串("")。
2.不得含有' '(空格)、.、$、/、\和\0 (空宇符)。
3.应全部小写。
4.最多64字节
集合的限制
1.集合名不能是空字符串""。
2.集合名不能含有\0字符(空字符),这个字符表示集合名的结尾。
3.集合名不能以"system."开头,这是为系统集合保留的前缀。
4.用户创建的集合名字不能含有保留字符。
文档的限制
1.文档中的键/值对是有序的。
2.文档中的值不仅可以是在双引号里
面的字符串,还可以是其他几种数据类
型
3.MongoDB区分类型和大小写。
4.MongoDB的文档不能有重复的键。
5.文档的键是字符串。
键的命名规范
1.键不能含有\0 (空字符)。这个字符用来表示键的结尾。
2. .和$有特别的意义,只有在特定环境下才能使用。
基础命令
启动
service mongod start
低版本启动
service mongod start
停止
service mongod stop
重置
service mongod restart
启动mongodb客户端
mongo
查看当前数据库
db
查看所有数据库
show dbs
切换数据库 (创建数据库)
use dbname
查看数据库的状态信息
db.stats()
详细信息每一项的含义
db:当前数据库的名字。
collections:当前数据库的集合数。
objects:当前数据库所有集合总所包含的对象(即文档)的数量。
avgObjSize:每个文档的平均大小(以字节为单位)。
dataSize:此数据库中保存的未压缩数据的总大小,不是指占有磁盘大小,单位是bytes。
storageSize:分配给此数据库的集合用于存储文档的空间总量,也就是当前数据库占有磁盘大小,单位是bytes。
numExtents:当前数据库所有集合包含的扩展数量的统计。
indexes:数据库中包含的所有集合的索引总数,也就是system.indexes表数据行数。
indexSize:此数据库上创建的所有索引的总大小,单位是bytes。
数据库删除:删除当前指向的数据库,如果数据库不存在,则什么也不做
查看数据库下的所有集合
show collection
删除数据库(删除当前所在的数据库)
db.dropDatabase()
创建集合和
db.createCollection('dbname') (非固定大小)
db.createCollection('dbname',{'capped':true,'size','1000','max':'10'}) (固定大小)
创建的集合的字段的选项
字段 类型 描述
capped 布尔 如果为 true,则创建固定集合。固定集合是指有着固定大小的集合,当达到最大值时,它会自动覆盖最早的文档。 当 该值为 true 时,必须指定 size 参数。
autolndexld 布尔 如为 true,自动在 _id 字段创建索引。默认为 false。
size 数值 为固定集合指定一个最大值.当文档达到上限时,会将之前的数据覆盖,单位为字节。如果 capped 为 true,也需要指定该字段。
max 数值 指定固定集合中包含文档的最大数量。
插入数据
db.collectionname.insert({document})
查找数据
db.students.find({})
db.students.find()
将数据以格式化的方式展示pretty()
db.集合名称.find().pretty()
关于ObjectId
ObjectId 类似唯一主键,可以很快的去生成和排序
每个文档都有一个属性,为_id,保证每个文档的唯一性
可以自己去设置_id插入文档
如果没有提供,那么MongoDB为每个文档提供了一个独特的_id,类型为objectID
objectID是一个12字节的十六进制数
前4个字节为当前时间戳
接下来3个字节的机器ID
接下来的2个字节中MongoDB的服务进程id
最后3个字节是简单的增量值
网友评论