Apache Spark FireDAC Components

Rapidly create and deploy powerful Delphi & C++Builder Apps that integrate with Apache Spark.

  • Connect to Apache Spark from Rad Studio Data Explorer.
  • Maps SQL to Spark SQL, enabling direct standard SQL-92 access to Apache Spark.

  download   buy now

CData FireDAC Components for Apache Spark
 Included in FireDAC Subscriptions: 125+ Components for real-time data access.

Extend Delphi & C++Builder Apps with unrivaled data connectivity!

Apache Spark FireDAC Components Included in Enterprise Subscriptions

Get the Apache Spark FireDAC Components together with 125+ additional components for SaaS, NoSQL, and Big Data integration! Our components offer the fastest & easiest way to build data driven Apps.

  • More than 125+ FireDAC Components for NoSQL, Big Data, & SaaS integration.
  • One year of free updates, upgrades, new releases, and support.

Learn More  

FireDAC Components in Action

Connecting to Any Data Source is as Easy as Connecting to a Database

Standard FireDAC Components

Just like connecting with a typical RDBMS like MySQL. or SQL Server. Use standard FireDAC components like TDFManager, TDFConnection, TDFQuery, etc.

FDConnection1.Name := 'ApacheSparkConnection';
FDConnection1.DriverName := 'CData.Fire.ApacheSpark';
with FDConnection1.Params as     
    TFDPhysCDataApacheSparkConnectionDefParams do begin


FDConnection1.Connected := true;
FDQuery1.Active := true;
FDQuery1.Open('select * from ApacheSpark');


Type SQL, Get Apache Spark

The easiest way to build data-centric applications. Write standard SQL queries to interact with Apache Spark, just like working with any RDBMS. Supports joins, updates, aggregation, and more.


SELECT ApacheSpark.Id, ApacheSpark.Name, ApacheSpark.Fax,     
  Opportunity.AccountId, Opportunity.CloseDate
FROM ApacheSpark
INNER JOIN Opportunity
  ON ApacheSpark.Id = Opportunity.AccountId


SELECT Name, AVG(AnnualRevenue) FROM ApacheSpark GROUP BY Name


UPDATE ApacheSpark SET Name='John' WHERE Id = @myId

Powerful Enterprise features