PHP: MongoDB的CRUD操作

资料:

  • 文档: https://packagist.org/packages/mongodb/mongodb
  • 驱动安装:https://docs.mongodb.com/drivers/php/
  • CURD: https://docs.mongodb.com/php-library/current/tutorial/crud/

安装

# 依赖扩展库 mongodb
$ pecl install mongodb
$ echo "extension=mongodb.so" >> `php --ini | grep "Loaded Configuration" | sed -e "s|.*:\s*||"`

$ composer require mongodb/mongodb

使用示例

<?php

require __DIR__ . '/vendor/autoload.php';


// 连接字符串
// mongodb://<username>:<password>@<address>:<port>
$client = new MongoDB\Client('mongodb://127.0.0.1:27017');

// $client->selectDatabase('data');
$db = $client->data;

// $db->selectCollection('users');
$table = $db->users;


// insert
$result = $table->insertOne([
    'name' => 'Tom',
    'age'  => 23,
]);

$result->getInsertedId();


// findOne
// 直接查询字符串形式的 _id不能获取到数据,需要传入一个ObjectId对象
$id = new MongoDB\BSON\ObjectId('6127613a52c83dfeff124962');

$result = $table->findOne([
    '_id' => $id
]);

var_dump($result);

echo $result['name'] . PHP_EOL; // Tom
echo $result['age'] . PHP_EOL; // 23
echo $result['_id'] . PHP_EOL; // 6127613a52c83dfeff124962


// 查询数量
$total = $table->countDocuments($where);


// 查询列表 条件 分页 排序 转数组
$list = $table->find($where, [
            'limit' => $size,
            'skip'  => ($page - 1) * $size,
            'sort'  => [
                // desc
                'update_time' => -1
            ],
        ])->toArray();
        
        
// updateOne
$result = $table->updateOne(
    ['_id' => $id],
    ['$set' => ['age' => 24]]
);


// deleteOne
$table->deleteOne(['_id' => $id]);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值