![]() |
VOOZH | about |
The Apache Solr platform is a popular, blazing-fast, open source enterprise search solution built on Apache Lucene.
Apache Solr is equipped with the Data Import Handler (DIH), which can import data from databases and, XML, CSV, and JSON files. When paired with the CData JDBC Driver for Beeminder, you can easily import Beeminder data to Apache Solr. In this article, we show step-by-step how to use CData JDBC Driver in Apache Solr Data Import Handler and import Beeminder data for use in enterprise search.
> solr create -c CDataCoreFor this article, Solr is running as a standalone instance in the local environment and you can access the core at this URL: http://localhost:8983/solr/#/CDataCore/core-overview
APIUniqueKey๐ Define schema in Solr for Beeminder data.
Now we are ready to use Beeminder data in Solr.
In this section, we walk through configuring the Data Import Handler.
<lib dir="${solr.install.dir:../../../..}/dist/" regex="solr-dataimporthandler-.*\.jar" />
<requestHandler name="/dataimport" class="org.apache.solr.handler.dataimport.DataImportHandler">
<lst name="defaults">
<str name="config">solr-data-config.xml</str>
</lst>
</requestHandler>
<dataConfig>
<dataSource driver="cdata.jdbc.api.APIDriver" url="jdbc:api:Profile=C:\profiles\Beeminder.apip;ProfileSettings='AuthToken=your_auth_token';">
</dataSource>
<document>
<entity name="ArchivedGoals"
query="SELECT Id,APIColumn1,APIColumn2,APIColumn3,APIColumn4,APIColumn5,APIColumn6,APIColumn7,LastModifiedDate FROM ArchivedGoals"
deltaQuery="SELECT Id FROM ArchivedGoals where LastModifiedDate >= '${dataimporter.last_index_time}'"
deltaImportQuery="SELECT Id,APIColumn1,APIColumn2,APIColumn3,APIColumn4,APIColumn5,APIColumn6,APIColumn7,LastModifiedDate FROM ArchivedGoals where Id=${dataimporter.delta.Id}">
<field column="Id" name="Id" ></field>
<field column="APIColumn1" name="APIColumn1" ></field>
<field column="APIColumn2" name="APIColumn2" ></field>
<field column="APIColumn3" name="APIColumn3" ></field>
<field column="APIColumn4" name="APIColumn4" ></field>
<field column="APIColumn5" name="APIColumn5" ></field>
<field column="APIColumn6" name="APIColumn6" ></field>
<field column="APIColumn7" name="APIColumn7" ></field>
<field column="LastModifiedDate" name="LastModifiedDate" ></field>
</entity>
</document>
</dataConfig>> solr stop -all > solr start
Using the CData JDBC Driver for Beeminder you are able to create an automated import of Beeminder data into Apache Solr. Download a free, 30 day trial of any of the hundreds of CData JDBC Drivers and get started today.
Connect to live data from Beeminder with the API Driver
Connect to Beeminder