我有一个字段在Solr的schema.xml中被索引为字符串,它来自mysql数据库中的boolean(tinyint)列。
在查询中,我使用1对此字段进行搜索。但如果不做任何更改,此查询将无法返回正确的结果。在我使用true而不是1之后,它又可以工作了。现在它又出错了,但如果是真的,1就没有问题。
这里确切的问题是什么?是否需要将schema.yml中的字段类型更改为整型?
提前谢谢你。
发布于 2011-01-06 14:08:49
因为它是一个字符串字段,我们不可能知道你是如何索引它的。它可以是"true“/ "false”或"1“/ "0”或"on“/ "off”等,或者甚至是这些的混合,也许你有一些文档带有"true“,一些文档带有"1”。
如果它在语义上是布尔型字段,我建议使用布尔型fieldType,例如:
<field name="inStock" type="boolean" indexed="true" stored="true" />为此,您需要声明布尔fieldType (它是在默认模式中声明的):
<fieldType name="boolean" class="solr.BoolField" sortMissingLast="true" omitNorms="true"/>请记住在此更改后重新构建索引。
https://stackoverflow.com/questions/4611820
复制相似问题