php mongo null,php中mongodb中的聚合查询返回null

我在rockmongo工具中运行了此命令

及其返回的正确值

{

aggregate : "twits",

pipeline : [

{$group : {_id : "$by", num_tutorial : {$sum : 1}}}

]

}

然后我尝试使用此方法从中提取值

define("__COLLECTION_TWITS__","twits");

在/var/www/html/TradeTwits/require/config/DBConfig.inc.php中

$collectionName=__COLLECTION_TWITS__;

$db = $this->connection("mo");

$col = $db->$collectionName;

return $col->aggregate(['$group'=> array('_id' => '$by','num_tutorial' => array($sum => 1))]);

在/var/www/html/TradeTwits/app/models/BaseModel.php中

上面的代码应返回按用户名分组的所有记录,

但是在php中时,它不能正常工作.

我正在使用使用PECL类库的phalcon框架来访问mongodb

和rockmongo作为访问mongodb集合的GUI

它为find()count()等返回正确的值.是否应该将另一个库用于聚合或管道?

解决方法:

集合应该是一个数组数组.我想在这里,您错过了一个数组.

该文件说:

$ops = array(

array(

'$project' => array(

"author" => 1,

"tags" => 1,

)

),

array('$unwind' => '$tags'),

array(

'$group' => array(

"_id" => array("tags" => '$tags'),

"authors" => array('$addToSet' => '$author'),

),

),

);

$results = $c->aggregate($ops);

标签:mongodb,php

来源: https://codeday.me/bug/20191119/2035253.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用MongoTemplate进行聚合查询来获取数据总数,您可以使用Aggregation类和AggregationOperation接口来构建聚合查询。以下是使用MongoTemplate来查询名为attendance的集合数据总数的示例代码: ```java import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.aggregation.Aggregation; import org.springframework.data.mongodb.core.aggregation.AggregationResults; import org.springframework.data.mongodb.core.aggregation.CountOperation; import org.springframework.data.mongodb.core.query.Criteria; public class Main { private final MongoTemplate mongoTemplate; public Main(MongoTemplate mongoTemplate) { this.mongoTemplate = mongoTemplate; } public long getAttendanceCount() { CountOperation countOperation = Aggregation.count().as("count"); Aggregation aggregation = Aggregation.newAggregation( Aggregation.match(Criteria.where("collectionName").is("attendance")), countOperation ); AggregationResults<CountResult> results = mongoTemplate.aggregate(aggregation, "system.namespaces", CountResult.class); CountResult countResult = results.getUniqueMappedResult(); if (countResult != null) { return countResult.getCount(); } else { return 0; } } public static void main(String[] args) { // 创建MongoTemplate实例 // MongoTemplate mongoTemplate = ...; Main main = new Main(mongoTemplate); long count = main.getAttendanceCount(); System.out.println("Attendance count: " + count); } private static class CountResult { private long count; public long getCount() { return count; } public void setCount(long count) { this.count = count; } } } ``` 请确保已经创建了MongoTemplate实例,并将其传递给Main类的构造函数。然后,可以调用getAttendanceCount方法来执行聚合查询并获取名为attendance的集合的数据总数。聚合查询通过匹配条件来筛选出名为attendance的集合,然后使用count操作来计算文档数量。最后,从聚合结果提取计数值并返回
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值