プロジェクトのニーズにより、プロジェクトは php7
にアップグレードされました。しかし、アップグレード後、mongo
拡張機能が使用できないことがわかりました。 php7.0
上記は mongodb
拡張機能のみをサポートしています。 mongodb
拡張ドライバーは、monmgo
拡張機能よりも使用するのが複雑で冗長です。長い間ネットで探していました。最後に、比較的単純な mongodb
クラスを見つけました。構文は mongo
に似ています。クリアでナチュラル。
プロジェクトアドレスhttps://github.com/mongodb/mongo-php-library
プロジェクトは外国人の友人によって寄稿されたものであるためです。したがって、読み取れる明確な文書はありません。一般的に使用される方法をいくつか紹介します。
インスタンスの取得
$uri = "mongodb://username:password@host/database"; $client = new \MongoDB\Client($uri);
ログイン後にコピー
コレクションの取得
$collection = $client->selectCollection('test','test');
ログイン後にコピー
データの一部の取得
$data = $collection->findOne(['id'=>1]);
ログイン後にコピー
複数のデータの取得
$where = ['type'=>1]; $options = array( 'projection' => array('id' => 1, 'age' => 1, 'name' => -1), // 指定返回哪些字段 1 表示返回 -1 表示不返回 'sort' => array('id' => -1), // 指定排序字段 'limit' => 10, // 指定返回的条数 'skip' => 0, // 指定起始位置 ); $data = $collection->find($where,$options)->toArray(); var_dump($data);
ログイン後にコピー
重複を削除
$fileName = 'name'; $where = ['id' => ['$lt' => 100]] $ret = $this->collection->distinct($fileName,$where);
ログイン後にコピー
データの一部を挿入
$data = array( 'id' => 2, 'age' => 20, 'name' => '张三' ); $ret = $collection->insertOne($data); $id=$ret->getInsertedId();
ログイン後にコピー
バッチ挿入
$data = array( ['id' => 1, 'age' => 21, 'name' => '1xiaoli'], ['id' => 2, 'age' => 22, 'name' => '2xiaoli'], ['id' => 3, 'age' => 23, 'name' => '3xiaoli'], ['id' => 4, 'age' => 26, 'name' => '4xiaoli'], ['id' => 5, 'age' => 24, 'name' => '5xiaoli'], ['id' => 6, 'age' => 25, 'name' => '6xiaoli'], ); $ret = $collection->insertMany($data); # 返回插入id var_dump($ret->getInsertedIds());
ログイン後にコピー
1 つの項目を更新
$ret = $collection->updateOne(array('id' => 2), array('$set' => array('age' => 56)));
ログイン後にコピー
複数の項目を更新
$ret = $collection->updateMany(array('id' => ['$gt' => 1]), array('$set' => array('age' => 56, 'name' => 'x')));
ログイン後にコピー
1 つの項目を削除item
$ret = $collection->deleteOne(array('id' => 2));
ログイン後にコピー
複数のアイテムを削除
$collection->deleteMany(array('id' => array('$in' => array(1, 2))));
ログイン後にコピー
集約
$ops = [ [ '$match' =>['type'=>['$in'=>[2,4]]] ], [ '$sort' => ['list.create_time' => -1] //sort顺序不能变,否则会造成排序混乱,注意先排序再分页 ], [ '$skip' => 0 ], [ '$limit' => 20000 ], ]; $data = $collection->aggregate($ops); foreach ($data as $document) { var_dump($document); }
ログイン後にコピー