成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

升級(jí)PHP7操作MongoDB

zlyBear / 2260人閱讀

摘要:在及以前,官方提供了兩個(gè)擴(kuò)展,和,其中是對(duì)以等幾個(gè)核心類為基礎(chǔ)的類群進(jìn)行操作,封裝得很方便,所以基本上都會(huì)選擇擴(kuò)展。這種想法很違背簡(jiǎn)化操作帶來(lái)的語(yǔ)法問(wèn)題而專注邏輯優(yōu)化的思路。

前言

使用 PHP+MongoDB 的用戶很多,因?yàn)?MongoDB 對(duì)非結(jié)構(gòu)化數(shù)據(jù)的存儲(chǔ)很方便。在 PHP5 及以前,官方提供了兩個(gè)擴(kuò)展,MongoMongoDB,其中 Mongo 是對(duì)以 MongoClient 等幾個(gè)核心類為基礎(chǔ)的類群進(jìn)行操作,封裝得很方便,所以基本上都會(huì)選擇 Mongo 擴(kuò)展。

詳情請(qǐng)見官方手冊(cè):http://php.net/manual/zh/book...

但是隨著 PHP5 升級(jí)到 PHP7,官方不再支持 Mongo 擴(kuò)展,只支持 MongoDB,而 PHP7 的性能提升巨大,讓人無(wú)法割舍,所以怎么把 Mongo 替換成 MongoDB 成為了一個(gè)亟待解決的問(wèn)題。MongoDB 引入了命名空間,但是功能封裝非常差,如果非要用原生的擴(kuò)展,幾乎意味著寫原生的 Mongo 語(yǔ)句。這種想法很違背 ORM 簡(jiǎn)化 DB IO 操作帶來(lái)的語(yǔ)法問(wèn)題而專注邏輯優(yōu)化的思路。

詳情也可參見官方手冊(cè):http://php.net/manual/zh/set....

在這種情況之下,MongoDB 官方忍不住了,為了方便使用,增加市場(chǎng)占有率,推出了基于MongoDB 擴(kuò)展的庫(kù):https://github.com/mongodb/mo...

該庫(kù)的詳細(xì)文檔見:https://docs.mongodb.com/php-...

MongoDB 驅(qū)動(dòng)

如果使用原驅(qū)動(dòng)的話,大致語(yǔ)法如下:

 "localhost",
            "port" => "27017",
            "username" => "",
            "password" => "",
            "database" => "test"
        ];

    public function __construct($config) {
        $config = array_merge($this->defaultConfig, $config);
        $mongoServer = "mongodb://";
        if ($config["username"]) {
            $mongoServer .= $config["username"] . ":" . $config["password"] . "@";
        }
        $mongoServer .= $config["hostname"];
        if ($config["port"]) {
            $mongoServer .= ":" . $config["port"];
        }
        $mongoServer .= "/" . $config["database"];

        $this->mongodb = new Manager($mongoServer);
        $this->database = $config["database"];
        $this->collection = $config["collection"];
        $this->bulk = new BulkWrite();
        $this->writeConcern = new WriteConcern(WriteConcern::MAJORITY, 100);
    }

    public function query($where = [], $option = []) {
        $query = new Query($where, $option);
        $result = $this->mongodb->executeQuery("$this->database.$this->collection", $query);

        return json_encode($result);
    }

    public function count($where = []) {
        $command = new Command(["count" => $this->collection, "query" => $where]);
        $result = $this->mongodb->executeCommand($this->database, $command);
        $res = $result->toArray();
        $count = 0;
        if ($res) {
            $count = $res[0]->n;
        }

        return $count;
    }

    public function update($where = [], $update = [], $upsert = false) {
        $this->bulk->update($where, ["$set" => $update], ["multi" => true, "upsert" => $upsert]);
        $result = $this->mongodb->executeBulkWrite("$this->database.$this->collection", $this->bulk, $this->writeConcern);

        return $result->getModifiedCount();
    }

    public function insert($data = []) {
        $this->bulk->insert($data);
        $result = $this->mongodb->executeBulkWrite("$this->database.$this->collection", $this->bulk, $this->writeConcern);

        return $result->getInsertedCount();
    }

    public function delete($where = [], $limit = 1) {
        $this->bulk->delete($where, ["limit" => $limit]);
        $result = $this->mongodb->executeBulkWrite("$this->database.$this->collection", $this->bulk, $this->writeConcern);

        return $result->getDeletedCount();
    }
}

這樣的語(yǔ)法和之前差異太大,改動(dòng)不方便,換 PHP MongoDB 庫(kù)

MongoDB 庫(kù) 1.連接

new MongoClient();

new MongoDBClient();
2.新增

$collention->insert($array, $options);

$resultOne = $collention->insertOne($array, $options);//單
$lastId = $resultOne->getInsertedId();
$resultMany = $collention->insertMany($array, $options);//多
$count = $resultMany->getInsertedCount();
3.修改

$collention->update($condition, [
    "$set" => $values
,[
    "multiple" => true//多條,單條false
]);

$collection->updateOne(
    ["state" => "ny"],
    ["$set" => ["country" => "us"]]
);
$updateResult = $collection->updateMany(
    ["state" => "ny"],
    ["$set" => ["country" => "us"]]
);
$count = $updateResult->getModifiedCount();
4.查詢

$cursor = $collection->find($condition, [
    "name" => true//指定字段
]);
$cursor->skip(5);
$cursor->limit(5);
$cursor->sort([
    "time" => -1
]);

$cursor = $collection->find($condition, [
    "skip" => 5,
    "limit" => 5,
    "sort" => [
        "time" => -1
    ],//排序
    "projection" => [
        "name" => 1//指定字段
    ]
]);
5.刪除

$collention->remove($condition, [
    "justOne" => false//刪單條
]);
$collention->remove([]);//刪所有

$result = $collention->deleteOne($condition, $options);
$collention->deleteMany($condition, $options);

$result->getDeletedCount();
補(bǔ)充

有些人可能習(xí)慣以類似 MySQL 的自增 ID 來(lái)處理數(shù)據(jù),以前可能使用 findAndModify() 方法來(lái)查詢并修改:

$collention->findAndModify([
    "_id" => $tableName//我在自增表中用其它的表名作主鍵
], [
    "$inc" => ["id" => 1]//自增
], [
    "_id" => 0
], [
    "new" => 1//返回修改后的結(jié)果,默認(rèn)是修改前的
]);

現(xiàn)在使用 MongoDB 庫(kù)的話需要修改為:

$collention->findOneAndUpdate([
    "_id" => $tableName
], [
    "$inc" => ["id" => 1]
], [
    "projection" => ["id" => 1],
    "returnDocument" => MongoDBOperationFindOneAndUpdate::RETURN_DOCUMENT_AFTER
]);

類似的還有 findOneAndDelete() findOneAndReplace(),更多內(nèi)容可見文檔

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/19309.html

相關(guān)文章

  • 升級(jí)PHP7 jenssegers/mongodb expected to be a referen

    摘要:上的擴(kuò)展有兩個(gè),都是官方出品的,一個(gè)叫,一個(gè)是,前者已經(jīng)被官方廢棄,不再提供穩(wěn)定的更新,官方推薦使用后者,并且后者是支持的。在上搜索即可找到,也可以通過(guò)安裝。使用作為中間件,不用修改現(xiàn)有代碼。 pecl上的mongodb擴(kuò)展有兩個(gè),都是官方出品的,一個(gè)叫mongo,一個(gè)是mongodb,前者已經(jīng)被官方廢棄,不再提供穩(wěn)定的更新,官方推薦使用后者,并且后者是支持php7的。在pecl上搜索...

    BicycleWarrior 評(píng)論0 收藏0
  • 升級(jí)PHP7 jenssegers/mongodb expected to be a referen

    摘要:上的擴(kuò)展有兩個(gè),都是官方出品的,一個(gè)叫,一個(gè)是,前者已經(jīng)被官方廢棄,不再提供穩(wěn)定的更新,官方推薦使用后者,并且后者是支持的。在上搜索即可找到,也可以通過(guò)安裝。使用作為中間件,不用修改現(xiàn)有代碼。 pecl上的mongodb擴(kuò)展有兩個(gè),都是官方出品的,一個(gè)叫mongo,一個(gè)是mongodb,前者已經(jīng)被官方廢棄,不再提供穩(wěn)定的更新,官方推薦使用后者,并且后者是支持php7的。在pecl上搜索...

    tangr206 評(píng)論0 收藏0
  • 升級(jí)PHP7操作MongoDB

    摘要:在及以前,官方提供了兩個(gè)擴(kuò)展,和,其中是對(duì)以等幾個(gè)核心類為基礎(chǔ)的類群進(jìn)行操作,封裝得很方便,所以基本上都會(huì)選擇擴(kuò)展。這種想法很違背簡(jiǎn)化操作帶來(lái)的語(yǔ)法問(wèn)題而專注邏輯優(yōu)化的思路。 前言 使用 PHP+MongoDB 的用戶很多,因?yàn)?MongoDB 對(duì)非結(jié)構(gòu)化數(shù)據(jù)的存儲(chǔ)很方便。在 PHP5 及以前,官方提供了兩個(gè)擴(kuò)展,Mongo 和 MongoDB,其中 Mongo 是對(duì)以 MongoCl...

    hizengzeng 評(píng)論0 收藏0
  • 項(xiàng)目切換PHP7.1.15

    摘要:也可以接入項(xiàng)目打包測(cè)試流程做代碼檢測(cè)。擴(kuò)展替換以后廢棄了和擴(kuò)展,項(xiàng)目中使用的使用的類使用的是已經(jīng)廢棄的擴(kuò)展使用擴(kuò)展做兼容替換。測(cè)試方案和大部分公司差不多,項(xiàng)目組劃分了線下開發(fā)環(huán)境預(yù)發(fā)布環(huán)境和生產(chǎn)環(huán)境三個(gè)環(huán)境。 項(xiàng)目由PHP5.5切換至PHP7.1.15 背景 從2015年鳥哥的技術(shù)分享,我們知道PHP7是對(duì)底層實(shí)現(xiàn)得一次完全重構(gòu),函數(shù)調(diào)用機(jī)制和內(nèi)存管理等很多方便做了優(yōu)化,使PHP性能有...

    tuniutech 評(píng)論0 收藏0
  • 推薦一個(gè)php7+ mongodb三方類

    摘要:由于項(xiàng)目需要,把項(xiàng)目升級(jí)到了。但是升級(jí)了之后發(fā)現(xiàn)擴(kuò)展不能用了。以上只支持?jǐn)U展了。而擴(kuò)展的驅(qū)動(dòng)使用起來(lái)比擴(kuò)展顯得很復(fù)雜,啰嗦。終于找到了一個(gè)比較簡(jiǎn)潔的類。項(xiàng)目地址因?yàn)轫?xiàng)目是國(guó)外友人貢獻(xiàn)的。這里整理了一些常用的方法。 由于項(xiàng)目需要,把項(xiàng)目升級(jí)到了php7。但是升級(jí)了之后發(fā)現(xiàn)mongo擴(kuò)展不能用了。php7.0以上只支持mongodb擴(kuò)展了。而mongodb擴(kuò)展的驅(qū)動(dòng)使用起來(lái)比monmgo擴(kuò)...

    U2FsdGVkX1x 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<