一個php7+mongodb三方類的介紹

來源:互聯網
上載者:User
本篇文章給大家帶來的內容是關於一個php7+mongodb三方類的介紹 ,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所協助。

由於項目需要,把項目升級到了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);# 返回插入idvar_dump($ret->getInsertedIds());

更新一條

$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')));

刪除一條

$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);}
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.