首頁 php教程 php手册 PHP驱动MongoDB整数问题的BUG和策略

PHP驱动MongoDB整数问题的BUG和策略

Jun 21, 2016 am 08:54 AM
mongo mongodb nbsp

本文所说的整数问题,其实并不是MongoDB的问题,而是PHP驱动的问题:MongoDB本身有两种整数类型,分别是:32位整数和64位整数,但旧版的PHP驱动不管操作系统是32位还是64位,把所有整数都当做32位整数处理,结果导致64位整数被截断。为了在尽可能保持兼容性的前提下解决这个问题,新版PHP驱动加入了mongo.native-long选项,以期在64位操作系统中把整数都当做64位来处理,有兴趣的可参考:64-bit integers in MongoDB

那么PHP驱动真的完全解决了整数问题么?NO!在处理group操作的时候还有BUG

为了说明问题,我们先来生成一些测试数据:

<font face="NSimsun"><?php <br/><br>ini_set("mongo.native_long", 1);<br><br>$instance = new Mongo();<br><br>$instance = $instance->selectCollection("test", "test");<br><br>for ($i = 0; $i     $instance->insert(array(<br>        "group_id" => rand(1, 5),<br>        "count"    => rand(1, 5),<br>    ));<br>}<br><br>?></font>

下面让我们使用group操作,根据group_id分组,汇总计算count:

<font size="2" face="新宋体"><?php <br/><br>ini_set("mongo.native_long", 1);<br><br>$instance = new Mongo();<br><br>$instance = $instance->selectCollection("test", "test");<br><br>$keys = array("group_id" => 1);<br><br>$initial = array("count" => 0);<br><br>$reduce = "<br>    function(obj, prev) {<br>        prev.count += obj.count;<br>    }<br>";<br><br>$result = $instance->group($keys, $initial, $reduce);<br><br>var_dump($result);<br><br>?></font>

结果和预想的有出入,count没有实现累加,而是变成了[object Object],目前,如果必须使用group操作,那么有两种方法可以缓解这个问题:

<font size="2" face="新宋体">ini_set("mongo.native_long", 0);</font>

<font size="2" face="新宋体">$initial = array("count" => (float)0);</font>

这两种方法都是治标不治本的权宜之计,既然当前PHP驱动里group的实现有问题,那我们就绕开它,用其它的方式实现同样的功能,这个方式就是MapReduce

<font size="2" face="新宋体"><?php <br/><br>ini_set("mongo.native_long", 1);<br><br>$instance = new Mongo();<br><br>$instance = $instance->selectDB("test");<br><br>$map = "<br>    function() {<br>        emit(this.group_id, this.count);<br>    }<br>";<br><br>$reduce = "<br>    function(key, values) {<br>        var sum = 0;<br><br>        for (var index in values) {<br>            sum += values[index];<br>        }<br><br>        return sum;<br>    }<br>";<br><br>$result = $instance->command(array(<br>    "mapreduce" => "test",<br>    "map"       => $map,<br>    "reduce"    => $reduce<br>));<br><br>$result = iterator_to_array($instance->{$result["result"]}->find());<br><br>var_dump($result);<br><br>?></font>

把大象放冰箱里需要三步,而使用MapReduce仅仅需要Map和Reduce两步即可,这里有一个PDF文档生动的说明了MySQL中GROUP BY和MongoDB中MapReduce的对应关系:

 

SQL to MongoDB

此外,还有很多资料可供参考,如:MongoDB Aggregation III: Map-Reduce Basics

说明:软件版本为MongoDB(1.6.5),PECL Mongo(1.1.4)。不同版本结论可能不同。



本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

navicat過期怎麼辦 navicat過期怎麼辦 Apr 23, 2024 pm 12:12 PM

解決 Navicat 過期問題的方法包括:續約授權;卸載並重新安裝;停用自動更新;使用 Navicat Premium Essentials 免費版;聯絡 Navicat 客戶支援。

前端學nodejs很難嗎 前端學nodejs很難嗎 Apr 21, 2024 am 04:57 AM

對於前端開發人員而言,學習 Node.js 的難度取決於其 JavaScript 基礎、伺服器端程式設計經驗、命令列熟悉度和學習風格。學習過程包括入門級和進階級的模組,重點是基礎概念、伺服器端架構、資料庫整合和非同步程式設計。整體而言,對於具備紮實 JavaScript 基礎並願意投入時間和精力的開發人員,學習 Node.js 並不困難,但對於缺乏相關經驗的人來說,可能需要克服一定的挑戰。

navicat怎麼連mongodb navicat怎麼連mongodb Apr 24, 2024 am 11:27 AM

要使用 Navicat 連接 MongoDB,您需要:安裝 Navicat建立 MongoDB 連接:a. 輸入連接名稱、主機位址和連接埠b. 輸入認證資訊(如果需要)新增 SSL 憑證(如果需要)驗證連線儲存連接

nodejs常用模組有哪些 nodejs常用模組有哪些 Apr 21, 2024 am 04:34 AM

Node.js 中最常用的模組包括:用於檔案操作的檔案系統模組用於網路通訊的網路模組用於處理資料流的流模組用於與資料庫互動的資料庫模組其他實用模組,如加密、查詢字符字串解析和HTTP 框架

nodejs用什麼資料庫好 nodejs用什麼資料庫好 Apr 21, 2024 am 05:06 AM

對於 Node.js 應用,選擇資料庫取決於應用程式要求。 NoSQL 資料庫 MongoDB 提供彈性,Redis 提供高並發性,Cassandra 處理時間序列數據,Elasticsearch 專用於搜尋。 SQL 資料庫 MySQL 效能出色,PostgreSQL 功能豐富,SQLite 輕量級,Oracle Database 全面。選擇時,需考慮資料類型、查詢、效能、事務性、可用性、許可和成本。

nodejs如何實作資料庫 nodejs如何實作資料庫 Apr 21, 2024 am 05:42 AM

在 Node.js 中連接資料庫需要選擇一個資料庫系統(關係型或非關係型),然後使用特定於該類型的模組建立連接。常見模組包括 mysql(MySQL)、pg(PostgreSQL)、mongodb(MongoDB)和 redis(Redis)。建立連線後,可以使用查詢語句檢索資料並使用更新語句修改資料。最後,完成所有操作後必須關閉連線以釋放資源。遵循這些最佳實務可提高效能和安全性,例如使用連線池、參數化查詢和妥善處理錯誤。

nodejs怎麼連接資料庫 nodejs怎麼連接資料庫 Apr 21, 2024 am 05:07 AM

在 Node.js 中連接資料庫的步驟:安裝 MySQL、MongoDB 或 PostgreSQL 套件。建立資料庫連接物件。打開資料庫連接,並處理連接錯誤。

net4.0有什麼用 net4.0有什麼用 May 10, 2024 am 01:09 AM

.NET 4.0 用於創建各種應用程序,它為應用程式開發人員提供了豐富的功能,包括:物件導向程式設計、靈活性、強大的架構、雲端運算整合、效能最佳化、廣泛的程式庫、安全性、可擴展性、資料存取和行動開發支援。

See all articles