如何在Solr中指定日期构面查询?

时间:2011-01-31 23:14:00

标签: solr

当我对Solr进行查询时,我得到了这些facet_counts:

'facet_counts' => {
    'facet_dates' => {
        'photo_added' => {
            '2009-12-28T18:00:00Z' => 396386,
            '2010-05-28T18:00:00Z' => 415370,
            'gap' => '+1MONTH',
            'end' => '2011-02-28T18:00:00Z',
        },
    },
},

但是,当我将{strong>这些参数中的任何一个添加到q=*:*查询时:

fq=photo_added:2009-12-28T18:00:00Z
fq=photo_added:2009-12-28T18%3A00%3A00Z

我收到此消息作为答复:

HTTP ERROR 400: Invalid Date String:'2009-12-28T18'

当我向<{1}}查询添加 这些参数任何一个时:

q=*:*

我在回复中收到了这个:

fq=photo_added:"2009-12-28T18:00:00Z"
fq=photo_added:"2009-12-28T18%3A00%3A00Z"
fq%3Dphoto_added%3A%222009-12-28T18%3A00%3A00Z%22
fq=photo_added%3A"2009-12-28T18%3A00%3A00Z"

但是当我的查询没有<result name="response" numFound="0" start="0"/> 约束时,我得到fq=,所以numFound="8001000"约束肯定有问题。

如何进行有效的日期构面查询?

1 个答案:

答案 0 :(得分:5)

我认为你错误地解释了日期方面的结果。 IIRC,由于您定义了1个月的差距,结果'2009-12-28T18:00:00Z' => 396386表示在2009-12-28T18:00:00Z和2010-01-28T18:00:00Z(一个月)之间有396386个结果。< / p>

但是,您正在运行带有完全日期的过滤器查询,并且您没有得到任何结果,因为没有文档与完全匹配该日期和时间。如果要获取这些396386文档,请运行一个过滤查询,其范围介于上述日期之间:fq=photo_added:[2009-12-28T18:00:00Z TO 2010-01-28T18:00:00Z]