Caution
This documentation has been moved to the centralized ScalarDB documentation repository, docs-internal-scalardb. Please update this documentation in that repository instead.
To view the ScalarDB documentation, visit ScalarDB Documentation.
ScalarDB FDW is a PostgreSQL extension that implements a foreign data wrapper (FDW) for ScalarDB.
ScalarDB FDW uses the Java Native Interface to directly utilize ScalarDB as a library inside the FDW and read data from external databases via scan operations for ScalarDB.
You must have the following prerequisites set up in your environment.
You must install a version of the Java Development Kit (JDK) that is compatible with ScalarDB. In addition, you must set the JAVA_HOME
environment variable, which points to your JDK installation directory.
Note that since these extensions use the Java Native Interface (JNI) internally, you must include the dynamic library of the Java virtual machine (JVM), such as libjvm.so
, in the library search path.
This extension supports PostgreSQL 13 or later. For details on how to install PostgreSQL, see the official documentation at Server Administration.
You can build and install this extension by running the following command.
make install
This section describes some common build errors that you might encounter.
Normally, the build script finds the path for libjvm.so
and properly sets it as a library search path. However, if you encounter the error ld: library not found for -ljvm
, please copy the libjvm.so
file to the default library search path. For example:
ln -s /<PATH_TO_YOUR_LIBJVM_FILE>/libjvm.so /usr/lib64/libjvm.so
This section provides a usage example and available options for FDW for ScalarDB.
The following example shows you how to install and create the necessary components, and then run a query by using the FDW extension.
For details on how to install the extension, see the Build and installation section.
To create an extension, run the following command:
CREATE EXTENSION scalardb_fdw;
To create a foreign server, run the following command:
CREATE SERVER scalardb FOREIGN DATA WRAPPER scalardb_fdw OPTIONS (
config_file_path '/path/to/scalardb.properties'
);
To create user mapping, run the following command:
CREATE USER MAPPING FOR PUBLIC SERVER scalardb;
To create a foreign table, run the following command:
CREATE FOREIGN TABLE sample_table (
pk int,
ck1 int,
ck2 int,
boolean_col boolean,
bigint_col bigint,
float_col double precision,
double_col double precision,
text_col text,
blob_col bytea
) SERVER scalardb OPTIONS (
namespace 'ns',
table_name 'sample_table'
);
To run a query, run the following command:
select * from sample_table;
You can set the following options for ScalarDB FDW objects.
You can set the following options on a ScalarDB foreign server object:
Name | Required | Type | Description |
---|---|---|---|
config_file_path |
Yes | string |
The path to the ScalarDB config file. |
max_heap_size |
No | string |
The maximum heap size of JVM. The format is the same as -Xmx . |
Currently, no options exist for CREATE USER MAPPING
.
The following options can be set on a ScalarDB foreign table object:
Name | Required | Type | Description |
---|---|---|---|
namespace |
Yes | string |
The name of the namespace of the table in the ScalarDB instance. |
table_name |
Yes | string |
The name of the table in the ScalarDB instance. |
ScalarDB | PostgreSQL |
---|---|
BOOLEAN | boolean |
INT | int |
BIGINT | bigint |
FLOAT | float |
DOUBLE | double precision |
TEXT | text |
BLOB | bytea |
This section describes how to test FDW for ScalarDB.
Before testing FDW for ScalarDB, you must have a running ScalarDB instance that contains test data. You can set up the instance and load the test data by running the following commands:
./test/setup.sh
If you want to reset the instances, you can run the following command, then the above setup command again.
./test/cleanup.sh
You can run regression tests by running the following command after you have installed the FDW extension.
make installcheck
- This extension aims to enable analytical query processing on ScalarDB-managed databases. Therefore, this extension only supports reading data from ScalarDB.