Ready to get started?

Download a free trial of the FHIR Driver to get started:

 Download Now

Learn more:

FHIR Icon FHIR JDBC Driver

Rapidly create and deploy powerful Java applications that integrate with FHIR.

Feed FHIR Data into FineReport



How to set FHIR data as a JDBC data source in FineReport.

The CData JDBC Driver for FHIR fully implements the JDBC standard and can provide FHIR data connectivity to a wide variety of BI, reporting, and ETL tools and custom applications. In this article, we explain how to set FHIR data as JDBC data source in FineReport and view FHIR data as a table in the Report Designer.

Set Up a JDBC Data Source of FHIR Data

Follow the instruction below to set FHIR data as a FineReport database connection.

  1. Copy the cdata.jdbc.fhir.jar file from the lib folder in the CData JDBC Driver for FHIR installation directory to the lib folder of the FineReport installation directory. You will need to copy the cdata.jdbc.fhir.lic file as well.
  2. From the Server tab, select Define Data Connection, click to add a new connection, and click JDBC.

Next we will set up the data connection definition in the window.

  1. Database: Others
  2. JDBC Driver: cdata.jdbc.fhir.FHIRDriver
  3. URL: A standard JDBC connection string using semicolon-separated connection properties.

    Set URL to the Service Base URL of the FHIR server. This is the address where the resources are defined in the FHIR server you would like to connect to. Set ConnectionType to a supported connection type. Set ContentType to the format of your documents. Set AuthScheme based on the authentication requirements for your FHIR server.

    Generic, Azure-based, AWS-based, and Google-based FHIR server implementations are supported.

    Sample Service Base URLs

    • Generic: http://my_fhir_server/r4b/
    • Azure: https://MY_AZURE_FHIR.azurehealthcareapis.com/
    • AWS: https://healthlake.REGION.amazonaws.com/datastore/DATASTORE_ID/r4/
    • Google: https://healthcare.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/datasets/DATASET_ID/fhirStores/FHIR_STORE_ID/fhir/

    Generic FHIR Instances

    The product supports connections to custom instances of FHIR. Authentication to custom FHIR servers is handled via OAuth (read more about OAuth in the Help documentation. Before you can connect to custom FHIR instances, you must set ConnectionType to Generic.

    Built-in Connection String Designer

    For assistance in constructing the JDBC URL, use the connection string designer built into the FHIR JDBC Driver. Either double-click the JAR file or execute the jar file from the command-line.

    java -jar cdata.jdbc.fhir.jar

    Fill in the connection properties and copy the connection string to the clipboard.

    When you configure the JDBC URL, you may also want to set the Max Rows connection property. This will limit the number of rows returned, which is especially helpful for improving performance when designing reports and visualizations.

    A typical JDBC URL is below:

    jdbc:fhir:URL=http://test.fhir.org/r4b/;ConnectionType=Generic;ContentType=JSON;AuthScheme=None;
  4. Click Connection pool attributes and set Test before getting connections to No.

Click Test connection to ensure you have configured the connection properly. With the connection to FHIR set up, you can use it as FineReport data source.

Select FHIR Data in the Report Designer.

  1. Click to add a new template data set and select DB query to open the database query window.
  2. Choose the JDBC connection that you created from the dropdown list.
  3. The FHIR entities will appear as tables on the left pane.
  4. Write a SELECT statement for the FHIR data tables and columns that you want to load.
  5. Click preview and data is shown as table.

With these simple steps, FHIR can be used as a JDBC data source in FineReport.