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

php中文网
发布: 2016-07-13 10:28:08
原创
984人浏览过

   本文所说的整数问题,其实并不是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:

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

  ini_set('mongo.native_long', 1);

  $instance = new Mongo();

立即学习PHP免费学习笔记(深入)”;

  $instance = $instance->selectCollection('test', 'test');

  for ($i = 0; $i

  $instance->insert(array(

  'group_id' => rand(1, 5),

  'count' => rand(1, 5),

  ));

  }

  ?>

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

  ini_set('mongo.native_long', 1);

  $instance = new Mongo();

立即学习PHP免费学习笔记(深入)”;

  $instance = $instance->selectCollection('test', 'test');

  $keys = array('group_id' => 1);

  $initial = array('count' => 0);

  $reduce = '

  function(obj, prev) {

  prev.count += obj.count;

  }

  ';

  $result = $instance->group($keys, $initial, $reduce);

  var_dump($result);

  ?>

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

  ini_set('mongo.native_long', 0);

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人

  $initial = array('count' => (float)0);

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

  ini_set('mongo.native_long', 1);

  $instance = new Mongo();

立即学习PHP免费学习笔记(深入)”;

  $instance = $instance->selectDB('test');

  $map = '

  function() {

  emit(this.group_id, this.count);

  }

  ';

  $reduce = '

  function(key, values) {

  var sum = 0;

  for (var index in values) {

  sum += values[index];

  }

  return sum;

  }

  ';

  $result = $instance->command(array(

  'mapreduce' => 'test',

  'map' => $map,

  'reduce' => $reduce

  ));

  $result = iterator_to_array($instance->{$result['result']}->find());

  var_dump($result);

  ?>

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

PHP驱动MongoDB整数问题的BUG和策略  帮客之家

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/814346.htmlTechArticle本文所说的整数问题,其实并不是MongoDB的问题,而是PHP驱动的问题:MongoDB本身有两种整数类型,分别是:32位整数和64位整数,但旧版的...
相关标签:
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号