# 安装(docker)

docker run -itd --name mongo -p 27017:27017 mongo --auth
docker exec -it mongo mongosh admin
1
2

创建 admin/123456 账号

use admin
db.createUser({ user:'admin',pwd:'123456',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
db.auth('admin', '123456')
1
2
3

# 连接

mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]

  • mongodb:// 这是固定的格式,必须要指定。
  • username:password@ 可选项,如果设置,在连接数据库服务器之后,驱动都会尝试登录这个数据库
  • host1 必须的指定至少一个host, host1 是这个URI唯一要填写的。它指定了要连接服务器的地址。如果要连接复制集,请指定多个主机地址。
  • portX 可选的指定端口,如果不填,默认为27017
  • /database 如果指定username:password@,连接并验证登录指定数据库。若不指定,默认打开 test 数据库。
  • ?options 是连接选项。如果不使用/database,则前面需要加上/。所有连接选项都是键值对name=value,键值对之间通过&或;(分号)隔开

标准的连接格式包含了多个选项(options),如下所示:

选项 描述
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的时间。

# 基本使用

# 创建和切换
use gangan

# 查看数据库
show dbs

# gangan集合写入数据
db.gangan.insert({"name":"test"})

# 删除数据库
use gangan
db.dropDatabase()

# 创建集合
db.createCollection(name, options)
# 创建固定集合 mycol,整个集合空间大小 6142800 B, 文档最大个数为 10000 个。
db.createCollection("mycol", { capped : true, autoIndexId : true, size : 
   6142800, max : 10000 } )
   
# 查看集合
show collections
show tables

# 删除集合
db.mycol.drop()

# 插入文档
db.COLLECTION_NAME.insertOne(document)
或
db.COLLECTION_NAME.replaceOne(document)

db.col.insert({title: 'test', name: 'MongoDB数据库'})
db.col.find()

# 更新文档
db.col.update({'title':'test'},{$set:{'title':'MongoDB'}},{multi:true})

# 删除文档
db.col.remove({'title':'MongoDB'})

# 查询文档
db.col.find().pretty()
db.col.findOne()

# 排序,title字段显示,likes按照倒叙
db.col.find({},{"title":1,_id:0}).sort({"likes":-1})

# limit skip(类似page跳过)
db.col.find({},{"title":1,_id:0}).limit(2)
db.col.find({},{"title":1,_id:0}).limit(1).skip(1)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50

# 查询

# 索引

# 聚合

# PHP操作

安装扩展

pecl install mongodb
1

添加 extension=mongodb.so 配置 php.ini

  • Driver\Manager 入口文件,一般都要先实例化该类
  • Driver\BulkWrite 读写类,数据库的增、删、改都要先靠该类来实现
  • Driver\Query 查询类,MongoDB支持丰富的查询方式,所以单独拿出来组建了一个类
  • Driver\Cursor 返回结果类,其实就是一个Cursor类的一个对象,该类有内置的toArray()函数可以结果转换成数组形式的
  • BSON\ObjectID MongoDB默认创建的索引是 _id,在添加的时候可以指定_id,给类就是可以创建一个指定内容的_id

# 插入数据

$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
$bulk = new MongoDB\Driver\BulkWrite;
$bulk->insert(['id' => 1, 'name'=>'测试', 'url' => 'http://www.百度.com']);
$manager->executeBulkWrite('test.wj', $bulk);
1
2
3
4

# 查询数据

$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
$filter = ['name' => '测试'];
$options = [
    'projection' => ['_id' => 0],
    'sort' => ['name' => -1],
];
$query = new MongoDB\Driver\Query($filter, $options);
$cursor = $manager->executeQuery('test.wj', $query);
foreach ($cursor as $document) {
    print_r($document);
}
1
2
3
4
5
6
7
8
9
10
11

# 更新数据

$bulk = new MongoDB\Driver\BulkWrite;
$bulk->update(
    ['id' => 1],
    ['$set' => ['name' => '测试1234']],
    ['multi' => false, 'upsert' => false]  #multi表示只更新一条数据,upsert表示如果不存在update的记录,不进行插入操作
);
$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite('test.wj', $bulk, $writeConcern);
1
2
3
4
5
6
7
8
9

# 删除数据

$bulk = new MongoDB\Driver\BulkWrite;
$bulk->delete(['id' => 1], ['limit' => 1]);   // limit 为 1 时,删除第一条匹配数据
$bulk->delete(['id' => 2], ['limit' => 0]);   // limit 为 0 时,删除所有匹配数据
$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite('test.wj', $bulk, $writeConcern);
1
2
3
4
5
6

# 参考资料