您好!欢迎来到雅安论坛
关注我们
扫码关注官方微信
手机版
手机扫描直接访问
欢迎: 附近的朋友。
热搜: 溯源 暴雨
111111

php报错BSON field 'count.query' is the wrong type 'array', expected type 'obj...

[复制链接]
本站网友  发表于 2022-4-17 22:55:44 |阅读模式 打印 上一主题 下一主题
php报错BSON field 'count.query' is the wrong type 'array', expected type 'object'问题解决
Thinkphp在连接使用Mongodb的时候,做数据分页或者查询数据总数需要使用count()方法,出现报错信息:BSON field 'count.query' is the wrong type 'array', expected type 'object'。
报错原因:
在think-mongo版本,vendor/topthink/think-mongo/src/Builder.php文件中,parseWhere方法在做过滤条件初始化的时候,没有考虑周全,将数据类型定义为了数组。

解决办法:
在parseWhere方法返回的时候做一个判断,如果$filter为空,就重新定义为stdClass对象。

修改的方法就是在return前添加如下代码:

// 修改代码 开始
if (empty($filter)){ // 返回空对象
    return new \stdClass();
}
// 修改代码 结束
完整parseWhere方法参考以下代码:

/**
* 生成查询过滤条件
* @access public
* @param Query $query 查询对象
* @param mixed $where
* @return array
*/
public function parseWhere(Query $query, $where)
{
    if (empty($where)) {
        $where = [];
    }

    $filter = [];
    foreach ($where as $logic => $val) {
        foreach ($val as $field => $value) {
            if (is_array($value)) {
                if (key($value) !== 0) {
                    throw new Exception('where express error:' . var_export($value, true));
                }
                $field = array_shift($value);
            } elseif (!($value instanceof \Closure)) {
                throw new Exception('where express error:' . var_export($value, true));
            }

            if ($value instanceof \Closure) {
                // 使用闭包查询
                $query = new Query($this->connection);
                call_user_func_array($value, [ & $query]);
                $filter[$logic][] = $this->parseWhere($query, $query->getOptions('where'));
            } else {
                if (strpos($field, '|')) {
                    // 不同字段使用相同查询条件(OR)
                    $array = explode('|', $field);
                    foreach ($array as $k) {
                        $filter['$or'][] = $this->parseWhereItem($query, $k, $value);
                    }
                } elseif (strpos($field, '&')) {
                    // 不同字段使用相同查询条件(AND)
                    $array = explode('&', $field);
                    foreach ($array as $k) {
                        $filter['$and'][] = $this->parseWhereItem($query, $k, $value);
                    }
                } else {
                    // 对字段使用表达式查询
                    $field            = is_string($field) ? $field : '';
                    $filter[$logic][] = $this->parseWhereItem($query, $field, $value);
                }
            }
        }
    }

    $options = $query->getOptions();
    if (!empty($options['soft_delete'])) {
        // 附加软删除条件
        list($field, $condition) = $options['soft_delete'];
        $filter['$and'][]        = $this->parseWhereItem($query, $field, $condition);
    }

    // 修改代码 开始
    if (empty($filter)){ // 返回空对象
        return new \stdClass();
    }
    // 修改代码 结束

    return $filter;
}




作者:zqifa

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

关注3

粉丝13

帖子2251

发布主题
阅读排行 更多
广告位
欢迎使用无需登录在线留言
姓名 

手机 

内容
关注我们
  • 关注官方微信

  • 论坛QQ群

Sitemap小黑屋Archiver雅安论坛( 已经安全运行 ) |网站地图

在线客服

会员收集的资源(插件源码等),仅方便学习,您需要自行承担版权风险,未获得原作者授权的情况下,请勿将文章公开发布或用于商业用途。

声明:本站内容来自于论坛作者本人的观点,不代表本网站的观点和看法,与本网站立场无关,相关责任作者自负。如有侵权,请联系我们及时删除

高能预警:本站为个人网站,非团队运作,常年务农,山上信号不好,在线少,如有不妥之处,望大佬们多多包涵,万分感激!

雅安论坛互联网违法和不良信息举报平台 您也可以通过留言进行相关问题提交,留言提交无需注册,我们将严格保证用户隐私。   © 2009-2021