为现代应用程序开发人员和云时代构建的基于文档的通用分布式数据库。 没有数据库可以提高您的生产力。
1. 运行服务/客户端、概念
服务: ./mongod.exe
客户端: ./mongo.exe
结构:
1 | 数据库 -> 数据库表/集合 -> 数据记录行/文档 -> 数据字段/域 |
保留数据库名: admin
、local
、config
文档(Document):
- 是一组键值对key-value,BSON,如:
{"name":"abc", "content":"def"}
- 键值对是有序的
- 区分类型和大小写
- 不能有重复的键
- 键是字符串
- 键不能包含空字符、.、$
- 下划线_保留,不推荐使用
集合:一个文档插入时,集合就会被创建
集合名不能包含空字符,不能以 system.
开头
capped collections:
1 | db.createCollection("mycoll", {capped:true, size:100000}) |
元数据
数据库的信息是存储在集合中。它们使用了系统的命名空间:
- dbname.system.*
- dbname.system.namespaces列出所有名字空间。
- dbname.system.indexes 列出所有索引。
- dbname.system.profile 包含数据库概要(profile)信息。
- dbname.system.users 列出所有可访问数据库的用户。
- dbname.local.sources 包含复制对端(slave)的服务器信息和状态。
数据类型
类型 | 描述 |
---|---|
String | 字符串。存储数据常用的数据类型。在 MongoDB 中,UTF-8 编码的字符串才是合法的。 |
Integer | 整型数值。用于存储数值。根据你所采用的服务器,可分为 32 位或 64 位。 |
Boolean | 布尔值。用于存储布尔值(真/假)。 |
Double | 双精度浮点值。用于存储浮点值。 |
Min /Max keys | 将一个值与 BSON(二进制的 JSON)元素的最低值和最高值相对比。 |
Array | 用于将数组或列表或多个值存储为一个键。 |
Timestamp | 时间戳。记录文档修改或添加的具体时间。 |
Object | 用于内嵌文档。 |
Null | 用于创建空值。 |
Symbol | 符号。该数据类型基本上等同于字符串类型,但不同的是,它一般用于采用特殊符号类型的语言。 |
Date | 日期时间。用 UNIX 时间格式来存储当前日期或时间。你可以指定自己的日期时间:创建 Date 对象,传入年月日信息。 |
Object ID | 对象 ID。用于创建文档的 ID。 |
Binary Data | 二进制数据。用于存储二进制数据。 |
Code | 代码类型。用于在文档中存储 JavaScript 代码。 |
Regular expression | 正则表达式类型。用于存储正则表达式。 |
ObjectId
ObjectId 类似唯一主键,可以很快的去生成和排序,包含 12 bytes,含义是:
前 4 个字节表示创建 unix 时间戳,格林尼治时间 UTC 时间,比北京时间晚了 8 个小时
接下来的 3 个字节是机器标识码,紧接的两个字节由进程 id 组成 PID,最后三个字节是随机数
文档必须有一个 _id 键。这个键的值可以是任何类型的,默认是个 ObjectId 对象
由于 ObjectId 中保存了创建的时间戳,所以你不需要为你的文档保存时间戳字段,你可以通过 getTimestamp 函数来获取文档的创建时间:
1 | > var newObject = ObjectId() |
ObjectId 转为字符串
1 | > newObject.str |
日期
表示当前距离 Unix新纪元(1970年1月1日)的毫秒数。日期类型是有符号的, 负数表示 1970 年之前的日期。
1 | > var mydate1 = new Date() //格林尼治时间 |
用户的权限
默认是没有用户名及密码的,即无权限访问限制。为了方便数据库的管理和安全,需创建数据库用户。
1 | Read 允许用户读取指定数据库 |
创建管理员用户
1 | > use admin |
创建完成后在配置文件中开启用户验证
1 | cat >>/application/mongodb/conf/mongod.conf<<-'EOF' |
重启服务
1 | /etc/init.d/mongod restart |
命令行中进行登陆
1 | mongo -uroot -proot admin |
创建对某库的只读用户,在test库创建只读用户test
1 | > use test |
测试用户是否创建成功
1 | > db.auth("test","test"); |
登录test用户,并测试是否只读
1 | > show collections; |
创建某库的读写用户,创建test1用户,权限为读写
1 | > db.createUser( |
查看并测试用户
1 | > show users; |
创建对多库不同权限的用户,创建对app为读写权限,对test库为只读权限的用户
1 | > use app |
查看并测试用户
1 | > show users; |
删除用户,删除app用户:先登录到admin数据库
1 | mongo -uroot –proot 127.0.0.1/admin |
进入app库删除app用户
1 | > use app; |
自定义数据库,创建app数据库的管理员:先登录到admin数据库
1 | > use app; |
创建app数据库读写权限的用户并具有clusterAdmin权限:
1 | > use app; |
2. 基本命令
数据库版本:
1 | > db.version(); |
连接机器地址:
1 | > db.getMongo(); |
显示所有数据库
1 | > show dbs; |
显示当前所在库
1 | > db; |
当前数据库状态:
1 | > db.stats(); |
切换到local库
1 | > use local; |
显示所有表/集合
1 | > show tables; |
创建数据库
1 | > use newdb; |
删除数据库
1 | > use newdb; |
删除集合
1 | > db.collection.drop(); |
创建集合
1 | db.createCollection(name, options); |
重命名集合
1 | > db.mycol.renameCollection("mycol1"); |
创建mycol集合
1 | > use newdb; |
插入1w行数据
1 | > for(i=0; i<10000; i++) { db.log.insert({ uid: i, name: "mongodb", age: 6, date: new Date()}); }; |
it显示下一页,默认每页显示20条记录,修改为50条记录
1 | > it |
查看第一条记录
1 | > db.log.findOne(); |
查看记录总数
1 | > db.log.count(); |
查看uid为1000的数据
1 | > db.log.find({uid:1000}); |
移除uid为1001的数据
1 | > db.log.remove({uid: 1001}); |
修改uid为1002的数据
1 | > db.log.update({ uid: 1002}, {$inc: { age: 3 }}, { multi: true}); |
删除集合总的记录数
1 | > db.log.distinct("name"); |
查看集合存储信息
1 | > db.log.stats(); // 查看数据状态 |
集合/表添加删除字段 join_date,集合没有数据结构的概念,但再document级可实现:
1 | > db.users.update({ }, { $set: { join_date: new Date() }}, { multi: true}); |
创建索引
1 | > db.users.createIndex( { user_id: 1 } ); |