首頁 >後端開發 >PHP7 >分享PHP7 MongoDB Driver 使用心得

分享PHP7 MongoDB Driver 使用心得

藏色散人
藏色散人轉載
2020-09-30 14:56:482739瀏覽

本文由PHP7教學專欄給大家分享PHP7 MongoDB Driver 使用心得,希望對需要的朋友有幫助!

分享PHP7 MongoDB Driver 使用心得

php7 只能使用Mongodb driver來驅動mongodb。

使用Mongodb Driver連接資料庫

剛開始使用Mongodb Driver的時候我是拒絕的。查看官方文件只看到一排的類別和不知所雲的成員方法,翻了半天也找不到find, update, delete等等關鍵字,更甚至稍微複雜一點的比如副本集,用戶認證都不知道怎麼連接資料庫。
幸好文件不是完全沒有,點開Mongodb\Driver\Manger::constructor 看到有幾個建構參數

  • $uri 形如mongo: //[host:port,host:port,host:port]/[dbname]?[username=aa&password=bb&replicaSet=cc]
  • $uriOptions 就是上面?後面的那一串參數,可以寫在這裡
  • $driverOptions 其他選項例如預設的讀寫參數

MongodbDriver CURD操作

#這就是我一開始覺得這個驅動反人類的地方,文檔裡沒有任何的find,update,delete等字眼,只有一個Command類別和一個Query類別
Query 類別稍微好一些,提供了部分查詢選項。
實際上,對Mongo資料庫的所有操作,都可以透過Command類別進行。而php的驅動文件對具體的 commandOptions 是不做介紹的。
正因為我是mongodb萌新,所以才會覺得這個驅動無比奇葩反人類,根本無從下手。
我們使用這個驅動的關鍵,是用Command類別建構一個commandOption
而這個commandOption需要我們從mongodb的官方文件中去了解
MONGODB MANUAL - Database Commands
所有的操作,資料增刪改查,聚合排序,資料庫狀​​態,使用者認證等等,都可以透過這些指令搞定。下面隨便舉幾個例子

  • 連接資料庫
$this->_conn = new MongoDB\Driver\Manager('mongodb://localhost:27017/test');
$this->_db = 'test';
// execute command.
function exec($opts) {
    $cmd = new MongoDB\Driver\Command($opts);
    $res =  $this->_conn->executeCommand($this->_db, $cmd);
    return $res->toArray();
}
  • #條件查詢,按需返回
$cmd = [
    'find' => 'table', // collection表名
    'filter' => ['_id' => ['$gte' => 10, '$lt' => 20]],
    'projection' => ['name' => 1, 'email' => 1]
];
$res = $this-exec($cmd);
  • 修改記錄
$cmd = [
    'update' => 'table', // collection 表名
    'updates' => [
        ['q' => [_id => ['$lt' => 10]], 'u' => ['status' => 0], 'upsert'=>0,'multi'=>1],
        ['q' => [_id => ['$gte' => 10]], 'u' => ['status' => 1], 'upsert'=>0,'multi'=>1],
    ],
    'ordered' => 1, // 是否依次执行updates语句,true表示执行失败后继续后面的语句,false 表示一旦失败立即返回
]
  • 刪除記錄,limit只能是1或0!
$cmd = [
    'delete' => 'table', // collection 表名
    'deletes' => [
        ['q' => [_id => ['$lt' => 5]], 'limit' => 0], // 0表示所有,1表示删除1行
    ]
]
  • 插入資料
$cmd = [
    'delete' => 'table', // collection 表名
    'deletes' => [
        ['q' => [_id => ['$lt' => 5]], 'limit' => 0], // 0表示所有,1表示删除1行
    ]
]
  • 分組,排序
$cmd = [
    'aggregate' => 'table', // collection 表名
    'pipeline' => [
        '$group' => 'class',
        '$sort' => 'score'
    ]
]
  • #讀取資料庫狀態
$cmd = [
    'replSetGetStatus' => 1,
]

輔助類別BSON

最有用的當然是MongoDB\BSON\JavascriptMongoDB\BSON\ObjectId ,分別是傳入javascript 腳本函數,和使用mongodb 的ojectid。

異常 Exception

所有MongoDBDriver 產生的例外都可以用 MongoDB\Driver\Exception\Exception 捕獲

以上是分享PHP7 MongoDB Driver 使用心得的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除