Skip to content

importing

David Berneda edited this page Jan 24, 2016 · 4 revisions

Importing data

Each "store" has a list of available "data" that has been imported or saved into it.

Data can be imported from different sources (files, databases, etc) into a common format (TDataItem class), and optionally persisted to local disk files in binary format for fast saving and loading.

Each data consists of the following files:

mydata.def

The *.def file is optional. It is only used for manually importing data using the Data Manager editor.

A *.def file is just an *.ini text file with the appropiate settings that define where is the source of the data to import and importing parameters, like a server connection name when importing a database.

These settings are manually edited using the Data Manager.

Programatically, *.def files can be created and modified using the TDataDefinition class

mydata.bi

A *.bi file is a binary file containing the information of the data structure. This is the number of "columns", type of each column and other parameters.

The TPersistence class (in BI.Persist.pas unit) allows reading and writing *.bi files at low-level.

mydata.databi

A *.databi file is a binary file containing the "real" data arrays, one array for each column, and optional arrays for the column "missing" (null) values and the "map" (index) of the column array.

The TDataPersistence class (in BI.Persist.pas unit) allows reading and writing *.databi files at low-level.

The "Data Manager" editor dialog, usable at design-time and runtime, allows adding/removing data items and configuring them to import and persist the data.

Importing data can also be done at runtime without the Data Manager editor, for example, importing an XML file:

uses BI.Data.XML;
var X : TBIXML;
X:=TBIXML.Create;

var Books : TDataItem;
Books:= X.Import('books.xml');

A simplified version of the above code automatically detects the file extension to avoid needing to create a TBIXML variable:

uses BI.DataSource, BI.Data.XML;
Books:= TBIFileSource.ImportFile('books.xml');

The same applies to files with *.json, *.csv, *.xls, *.cds etc extensions. Just using the appropiate BI.Data.xxx unit, enables the automatic extension discovery.

Other helper methods in TBIFileSource and importing classes:

-TBIFileSource.ImportURL( 'http://acme.com/mydata.json'); -X.Import( Memo1.Lines ); // any TStrings containing xml data -TBIFileSource.Import('c:\myfolder', '.', '', True) // recursive folder import -TBIDB.Import( FDConnection1 ); // database connections -TBIDatasetSource.Import( MyDataSet1 ); // any TDataset-derived

Data Manager dialog (and all other dialogs) are available for both VCL and Firemonkey frameworks:

Different sources can be configured in the Data Manager, like:

-Text files (CSV, JSON, XML) from a folder or an URL. -Microsoft Excel spreadsheets -Database connections (using FireDAC, SQLExpress or other libraries) -Data that is in another BIWeb server -Contents from compressed *.zip files

Notes about the different data formats and importing them:

The units and classes related to importing data (BI.Data.xxx) can be used also by code, with more methods and flexibility (like for example importing contents of a TMemo.Lines or TStrings, or importing a live TDataSet instance of any class).

XML, JSON and databases can be imported using a default "engine" or specifying a custom one.

The above example uses the "default" engine (just using the parameterless Create constructor).

For XML, the available engines are:

-XmlDom (the standard xml code included by default in Delphi) -Omni ( https://code.google.com/p/omnixml )

To specify an "engine", the only change is the import class should be created like:

uses BI.Data.XML.Omni;
X:=TBIXML.CreateEngine(TOmniXML.Create);

Similar to xml, JSON import supports:

-System.JSON (or DBXJSON for older Delphi versions) -SuperObject ( https://github.com/hgourvest/superobject )

and the same code to use any of them, for example:

uses BI.Data.JSON.SuperObject;
X:=TBIJSON.CreateEngine(TSuperObject.Create);

Importing databases can also be done specifying a different engine.

The available options are:

-FireDAC (or SqlExpress) -BDE -UniDAC

uses BI.Data.DB.SqlExpr;
X:=TBIDB.CreateEngine(TDBSqlExprEngine.Create);  // <-- use SqlExpress instead of FireDAC

Other "engines" will be implemented in the near future.

Clone this wiki locally