2017-07-26 76 views
0

我遇到了一個問題,試圖使用DataImportHandler從MySQL導入位置數據。用於我的子實體的一個查詢:Solr DataImportHandler與地理區域問題

SELECT [...] AS data, AsText(data_geo) AS data_geo FROM [table] WHERE [conditions] 

我已經運行的查詢和核實輸出看上去是正確的:

'128 Wall St, New Haven, CT 06511, USA', 'POINT(-72.92847010000003 41.31160920000001)' 

然而,當我嘗試運行的進口,我得到的以下情況除外:

SolrWriter.upload(73) | Error creating document : SolrInputDocument(fields: [[...], data=128 Wall St, New Haven, CT 06511, USA, data_geo=[[email protected], _version_=1573858358394355712]) 
org.apache.solr.common.SolrException: Point must be in 'lat, lon' or 'x y' format: [[email protected] 
     at org.apache.solr.util.SpatialUtils.parsePointSolrException(SpatialUtils.java:113) 
     at org.apache.solr.schema.AbstractSpatialFieldType.parseShape(AbstractSpatialFieldType.java:239) 
     at org.apache.solr.schema.AbstractSpatialFieldType.createFields(AbstractSpatialFieldType.java:201) 
     at org.apache.solr.update.DocumentBuilder.addField(DocumentBuilder.java:48) 
     at org.apache.solr.update.DocumentBuilder.toDocument(DocumentBuilder.java:123) 
     at org.apache.solr.update.AddUpdateCommand.getLuceneDocument(AddUpdateCommand.java:83) 
     at org.apache.solr.update.DirectUpdateHandler2.addDoc0(DirectUpdateHandler2.java:237) 
     at org.apache.solr.update.DirectUpdateHandler2.addDoc(DirectUpdateHandler2.java:163) 
     at org.apache.solr.update.processor.RunUpdateProcessor.processAdd(RunUpdateProcessorFactory.java:69) 
     at org.apache.solr.update.processor.UpdateRequestProcessor.processAdd(UpdateRequestProcessor.java:51) 
     at org.apache.solr.update.processor.DistributedUpdateProcessor.doLocalAdd(DistributedUpdateProcessor.java:955) 
     at org.apache.solr.update.processor.DistributedUpdateProcessor.versionAdd(DistributedUpdateProcessor.java:1110) 
     at org.apache.solr.update.processor.DistributedUpdateProcessor.processAdd(DistributedUpdateProcessor.java:706) 
     at org.apache.solr.update.processor.LogUpdateProcessor.processAdd(LogUpdateProcessorFactory.java:104) 
     at org.apache.solr.handler.dataimport.SolrWriter.upload(SolrWriter.java:71) 
     at org.apache.solr.handler.dataimport.DataImportHandler$1.upload(DataImportHandler.java:259) 
     at org.apache.solr.handler.dataimport.DocBuilder.buildDocument(DocBuilder.java:524) 
     at org.apache.solr.handler.dataimport.DocBuilder.buildDocument(DocBuilder.java:414) 
     at org.apache.solr.handler.dataimport.DocBuilder.doFullDump(DocBuilder.java:329) 
     at org.apache.solr.handler.dataimport.DocBuilder.execute(DocBuilder.java:232) 
     at org.apache.solr.handler.dataimport.DataImporter.doFullImport(DataImporter.java:416) 
     at org.apache.solr.handler.dataimport.DataImporter.runCmd(DataImporter.java:480) 
     at org.apache.solr.handler.dataimport.DataImporter$1.run(DataImporter.java:461) 
Caused by: com.spatial4j.core.exception.InvalidShapeException: Point must be in 'lat, lon' or 'x y' format: [[email protected] 
     at org.apache.solr.util.SpatialUtils.parsePoint(SpatialUtils.java:74) 
     at org.apache.solr.util.SpatialUtils.parsePointSolrException(SpatialUtils.java:108) 
     ... 22 more 

schema.xml中的相關配置爲:

<field name="data_geo" type="location_rpt" indexed="true" stored="true" multiValued="false" /> 

    <fieldType name="location_rpt" class="solr.SpatialRecursivePrefixTreeFieldType" 
     spatialContextFactory="com.spatial4j.core.context.jts.JtsSpatialContextFactory" 
     autoIndex="true" 
     geo="true" 
     distErrPct="0.025" 
     maxDistErr="0.001" 
     distanceUnits="kilometers" /> 

我正在運行Solr 5.2.1

任何想法爲什麼它試圖使用什麼似乎是Java對象哈希導入地理領域?

謝謝!

+0

在我的Solr 6.6.0中,這個問題依然存在。 – dmaz99

回答