Mongodb子文档日期范围返回错误结果
第一次在Stackoverflow。 我试图对数组集合运行日期范围查询,但Mongo Shell返回的无关文档与我的条件不匹配。我通过PHP驱动程序、Doctrine Mongodb查询生成器或MongoShell进行查询并不重要 我的问题是:Mongodb子文档日期范围返回错误结果,mongodb,date-range,doctrine-mongodb,mongo-collection,subdocument,Mongodb,Date Range,Doctrine Mongodb,Mongo Collection,Subdocument,第一次在Stackoverflow。 我试图对数组集合运行日期范围查询,但Mongo Shell返回的无关文档与我的条件不匹配。我通过PHP驱动程序、Doctrine Mongodb查询生成器或MongoShell进行查询并不重要 我的问题是: db.deals.find( { "total_sold.created_at": { $gt: new ISODate("2014-03-05T00:00:00Z"),
db.deals.find( { "total_sold.created_at":
{ $gt: new ISODate("2014-03-05T00:00:00Z"),
$lt: new ISODate("2014-03-05T23:59:00Z")
}
}).limit(1).pretty()
结果如下:
{
"_id" : "1241412fb99a11a0bc70032a2cb6059b",
"total_sold" : [
{
"some_field": "value",
"created_at" : ISODate("2014-02-13T15:48:35Z"),
},
{
"some_field": "value",
"created_at" : ISODate("2014-02-14T10:26:19Z"),
},
{
"some_field": "value",
"created_at" : ISODate("2014-02-15T11:36:50Z"),
},
{
"some_field": "value",
"created_at" : ISODate("2014-02-17T09:35:19Z"),
},
{
"some_field": "value",
"created_at" : ISODate("2014-02-19T16:34:52Z"),
},
{
"some_field": "value",
"created_at" : ISODate("2014-02-21T12:06:10Z"),
},
{
"some_field": "value",
"created_at" : ISODate("2014-02-24T09:52:23Z"),
},
{
"some_field": "value",
"created_at" : ISODate("2014-03-07T22:40:37Z"),
}
],
"updated_at" : ISODate("2014-03-07T22:40:40Z")
}
我试图查询“total_Selled.created_at”字段设置为“2014-03-05”的文档,但返回结果不包括在“2014-03-05”创建的任何子集合,我遗漏了什么?我试过$and运算符,“$total_sall.created_at”表示法等,但没有结果
Ps:字段中已售出的总数量。已创建的数量已编制索引
编辑:
我已经通过Doctrine Mongodb创建并保存了我的文档。这是我的Mongodb映射。主文件和总销售子文件
<?php
use Doctrine\ODM\MongoDB\Mapping\Annotations as ODM;
use Gedmo\Mapping\Annotation as Gedmo;
/**
* @ODM\Document(
* collection="deals",
* )
* @ODM\Index(keys={"total_sold"="desc"}),
*/
Class Deal {
/**
* @ODM\Id(strategy="NONE")
*/
protected $id;
/**
*Some other fields
**/
/**
* @ODM\EmbedMany(targetDocument="DealTotalSold")
*/
protected $total_sold;
/**
* Constructor
*/
public function __construct() {
$this->total_sold = new \Doctrine\Common\Collections\ArrayCollection();
}
/**
* Add totalSold
*
*/
public function addTotalSold($totalSold) {
$this->total_sold[] = $totalSold;
}
/**
* Remove totalSold
*
*/
public function removeTotalSold($totalSold) {
$this->total_sold->removeElement($totalSold);
}
/**
* Get totalSold
*
* @return Doctrine\Common\Collections\Collection $totalSold
*/
public function getTotalSold() {
return $this->total_sold;
}
}
<?php
use Doctrine\ODM\MongoDB\Mapping\Annotations as ODM;
use Gedmo\Mapping\Annotation as Gedmo;
/**
* @ODM\EmbeddedDocument
*/
Class DealTotalSold {
/**
* @ODM\Id(strategy="NONE")
*/
protected $id;
/**
* @ODM\Date
* @Gedmo\Timestampable(on="create")
*/
protected $created_at;
/**
* @ODM\Int
*/
protected $delta_totalsold;
public function __construct()
{
}
/**
* Set createdAt
*
* @param date $createdAt
* @return self
*/
public function setCreatedAt($createdAt)
{
$this->created_at = $createdAt;
return $this;
}
/**
* Get createdAt
*
* @return date $createdAt
*/
public function getCreatedAt()
{
return $this->created_at;
}
/**
* Set dealtaTotalsold
*
* @param Int $dealtaTotalsold
* @return self
*/
public function setDeltaTotalsold($dealtaTotalsold)
{
$this->delta_totalsold = $dealtaTotalsold;
return $this;
}
/**
* Set id
*
* @param custom_id $id
* @return self
*/
public function setId($id)
{
$this->id = $id;
return $this;
}
/**
* Get id
*
* @return custom_id $id
*/
public function getId()
{
return $this->id;
}
/**
* Get deltaTotalsold
*
* @return float $deltaTotalsold
*/
public function getDeltaTotalsold()
{
return $this->delta_totalsold;
}
}
必须使用$elemMatch运算符将数组元素中的多个组件与$and进行匹配
db.deals.find({ total_sold: { $elemMatch : {
$and:[ {created_at: {$gt: new ISODate("2014-03-05T00:00:00Z") }},
{ created_at: {$lt: new ISODate("2014-03-05T23:00:00Z") }}
]
}}
});
$elemMatch Doc:似乎您已经在内部创建了_作为JOSN阵列。发布您的示例JSON结构@UgurI。我已经编辑了我的问题,添加了Mongodb映射。我还应该提到,我正在使用时间表的条令扩展。感谢您的回答,并揭示了在数组中匹配字段的技巧。它正在按预期工作!干杯..欢迎来到stackoverflow:)对于那些感兴趣的人来说,这一次也像预期的那样有效。db.deals.find({total_seal:{$elemMatch:{created_at:{$gt:new ISODate(“2014-03-07T00:00:00Z”),$lt:new ISODate(“2014-03-07T23:59:59Z”)})