firebird_fdw
firebird_fdw : Foreign data wrapper for Firebird
Overview
| ID | Extension | Package | Version | Category | License | Language |
|---|---|---|---|---|---|---|
| 8750 | firebird_fdw
|
firebird_fdw
|
1.4.2 |
FDW
|
PostgreSQL
|
C
|
| Attribute | Has Binary | Has Library | Need Load | Has DDL | Relocatable | Trusted |
|---|---|---|---|---|---|---|
--s-d-r
|
No
|
Yes
|
No
|
Yes
|
yes
|
no
|
| Relationships | |
|---|---|
| See Also | mysql_fdw
oracle_fdw
tds_fdw
db2_fdw
wrappers
odbc_fdw
jdbc_fdw
postgres_fdw
|
Packages
| Type | Repo | Version | PG Major Compatibility | Package Pattern | Dependencies |
|---|---|---|---|---|---|
| EXT | PIGSTY
|
1.4.2 |
18
17
16
15
14
|
firebird_fdw |
- |
| RPM | PIGSTY
|
1.4.2 |
18
17
16
15
14
|
firebird_fdw_$v |
libfq |
| DEB | PIGSTY
|
1.4.2 |
18
17
16
15
14
|
postgresql-$v-firebird-fdw |
libfq |
| Linux / PG | PG18 | PG17 | PG16 | PG15 | PG14 |
|---|---|---|---|---|---|
el8.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
el8.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
el9.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
el9.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
el10.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
el10.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
d12.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
d12.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
d13.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
d13.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
u22.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
u22.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
u24.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
u24.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
u26.x86_64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
u26.aarch64
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
PIGSTY 1.4.2
|
Source
pig build pkg firebird_fdw; # build rpm/debInstall
Make sure PGDG and PIGSTY repo available:
pig repo add pgsql -u # add both repo and update cacheInstall this extension with pig:
pig install firebird_fdw; # install via package name, for the active PG version
pig install firebird_fdw -v 18; # install for PG 18
pig install firebird_fdw -v 17; # install for PG 17
pig install firebird_fdw -v 16; # install for PG 16
pig install firebird_fdw -v 15; # install for PG 15
pig install firebird_fdw -v 14; # install for PG 14Create this extension with:
CREATE EXTENSION firebird_fdw;Usage
Sources: upstream README, 1.4.2 README, 1.4.2 tag.
firebird_fdw connects PostgreSQL to Firebird databases through the foreign data wrapper API. It supports reads, writes, IMPORT FOREIGN SCHEMA, predicate pushdown for supported expressions, connection caching, and foreign-table TRUNCATE on PostgreSQL 14+.
Create Server
CREATE EXTENSION firebird_fdw;
CREATE SERVER firebird_server FOREIGN DATA WRAPPER firebird_fdw
OPTIONS (address 'localhost', database '/path/to/database.fdb');Server options include:
address, defaultlocalhost.port, default3050.database, the Firebird database name or path.updatable, defaulttrue; table-level settings can override it.disable_pushdowns, useful for debugging or benchmarking.quote_identifiers, to quote table and column identifiers by default.implicit_bool_type, for integer-backed Firebird boolean columns.batch_size, for multi-row inserts on PostgreSQL 14+.
Create User Mapping
CREATE USER MAPPING FOR CURRENT_USER SERVER firebird_server
OPTIONS (username 'sysdba', password 'masterke');Create Foreign Table
CREATE FOREIGN TABLE fb_test (
id smallint,
val varchar(2048)
)
SERVER firebird_server
OPTIONS (table_name 'fdw_test');With column name mapping:
CREATE FOREIGN TABLE fb_mapped (
id smallint OPTIONS (column_name 'test_id'),
val varchar(2048) OPTIONS (column_name 'test_val')
)
SERVER firebird_server
OPTIONS (table_name 'fdw_test');With a custom query, the foreign table is read-only:
CREATE FOREIGN TABLE fb_query (
id smallint,
val varchar(2048)
)
SERVER firebird_server
OPTIONS (query $$ SELECT id, val FROM fdw_test WHERE id > 10 $$);Table options include table_name, query, updatable, estimated_row_count, quote_identifier, and batch_size. Column options include column_name, quote_identifier, and implicit_bool_type.
Import Foreign Schema
IMPORT FOREIGN SCHEMA someschema
FROM SERVER firebird_server
INTO public
OPTIONS (import_views 'true', verbose 'true');Import options include import_not_null, import_views, updatable, and verbose. The schema name has no special Firebird meaning and can be any value accepted by PostgreSQL’s IMPORT FOREIGN SCHEMA syntax.
CRUD Operations
SELECT * FROM fb_test WHERE id > 5;
INSERT INTO fb_test VALUES (10, 'new record');
UPDATE fb_test SET val = 'updated' WHERE id = 10;
DELETE FROM fb_test WHERE id = 10;
TRUNCATE fb_test;UPDATE and DELETE use Firebird’s RDB$DB_KEY. TRUNCATE is implemented as an unqualified Firebird DELETE because Firebird has no native TRUNCATE statement.
Utility Functions
firebird_fdw_version()returns the FDW version as an integer.firebird_fdw_close_connections()closes cached Firebird connections for the current PostgreSQL session.firebird_fdw_server_options(servername text)shows effective server option values and whether each was explicitly provided.firebird_fdw_diag()returns diagnostic key/value data, including FDW andlibfqversions.firebird_version()reports Firebird server versions for configured foreign servers and may open connections to do so.
Caveats
- Pigsty packages
firebird_fdw1.4.2 for PostgreSQL 14-18. Upstream documents compatibility with PostgreSQL 10-19, with newer FDW API features available only on newer PostgreSQL releases. - Upstream supports Firebird 2.5 and later; older Firebird versions are not a tested target.
firebird_fdwandlibfqare developed together, so package compatibility depends on matching those libraries.- Custom-query foreign tables cannot be updated.
- The
implicit_bool_typefeature is experimental and is designed around integer columns representing boolean values.