ScalarDB FDW
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.
Prerequisites
You must have the following prerequisites set up in your environment.
JDK
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.
PostgreSQL
This extension supports PostgreSQL 13 or later. For details on how to install PostgreSQL, see the official documentation at Server Administration.
Build and installation
You can build and install this extension by running the following command.
make install
Common build errors
This section describes some common build errors that you might encounter.
ld: library not found for -ljvm
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
Usage
This section provides a usage example and available options for FDW for ScalarDB.
Example
The following example shows you how to install and create the necessary components, and then run a query by using the FDW extension.
1. Install the extension
For details on how to install the extension, see the Build and installation section.
2. Create an extension
To create an extension, run the following command:
CREATE EXTENSION scalardb_fdw;
3. Create a foreign server
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'
);
4. Create user mapping
To create user mapping, run the following command:
CREATE USER MAPPING FOR PUBLIC SERVER scalardb;
5. Create a foreign table
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'
);
6. Run a query
To run a query, run the following command:
select * from sample_table;
Available options
You can set the following options for ScalarDB FDW objects.
CREATE SERVER
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 . |
CREATE USER MAPPING
Currently, no options exist for CREATE USER MAPPING
.
CREATE FOREIGN SERVER
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. |
Data-type mapping
ScalarDB | PostgreSQL |
---|---|
BOOLEAN | boolean |
INT | int |
BIGINT | bigint |
FLOAT | float |
DOUBLE | double precision |
TEXT | text |
BLOB | bytea |