2011-01-06 39 views
3

我有一个字段在索引的schema.xml中索引为字符串,它来自mysql数据库中的布尔(tinyint)列。solr搜索结果中的字段值为1或true

在查询中,我使用1对该字段进行搜索。但没有任何更改,此查询无法返回正确的结果。在我使用true而不是1之后,它再次运行。现在它再次出现错误,但与真实,没有问题1.

这里有什么确切的问题?我是否需要将schema.yml中的字段类型更改为整数?

预先感谢您。

回答

5

由于它是一个字符串字段,我们不可能知道如何为它编制索引。它可以是“真”/“假”或“1”/“0”或“开”/“关”等。或者甚至可以是这些的混合,也许你有一些文档具有“真实” ”。

如果它是语义上一个布尔字段我建议使用布尔字段类型,如:

<field name="inStock" type="boolean" indexed="true" stored="true" /> 

这个工作,你需要申报(它有默认的模式中声明)布尔字段类型:

<fieldType name="boolean" class="solr.BoolField" sortMissingLast="true" omitNorms="true"/> 

请记住在此更改后重建索引。