2017-07-26 16 views
0

DataImportHandlerを使用してMySQLから位置データをインポートしようとすると、問題が発生しています。私のサブエンティティのいずれかのクエリは次のとおりです。Solo 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

答えて

関連する問題