Key features v2
These are the key features of the MySQL Foreign Data Wrapper.
Writable foreign data wrapper
MySQL Foreign Data Wrapper provides the write capability. You can insert, update, and delete data in the remote MySQL tables by inserting, updating, and deleting the data locally in the foreign tables. MySQL foreign data wrapper uses the Postgres type casting mechanism to provide opposite type casting between MySQL and Postgres data types.
Note
The first column of MySQL table must have unique/primary key for DML to work.
See also:
Connection pooling
MySQL Foreign Data Wrapper establishes a connection to a foreign server during the first query that uses a foreign table associated with the foreign server. This connection is kept and reused for subsequent queries in the same session.
WHERE clause pushdown
MySQL Foreign Data Wrapper allows the pushdown of a WHERE
clause to the foreign server for execution. This feature optimizes remote queries to reduce the number of rows transferred from foreign servers.
Column pushdown
MySQL Foreign Data Wrapper supports column pushdown. As a result, the query brings back only those columns that are a part of the select target list.
Join pushdown
MySQL Foreign Data Wrapper supports join pushdown. It pushes the joins between the foreign tables of the same remote MySQL server to that remote MySQL server, enhancing the performance.
Note
- Currently, joins involving only relational and arithmetic operators in join clauses are pushed down to avoid any potential join failure.
- Only the INNER and LEFT/RIGHT OUTER joins are supported.
See also:
- Example: Join pushdown
- Blog: Join Pushdown - covers performance improvements and partition-wise join pushdowns
Aggregate pushdown
MySQL Foreign Data Wrapper supports aggregate pushdown for min, max, sum, avg, and count aggregate functions, allowing you to push aggregates to the remote MySQL server instead of fetching all of the rows and aggregating them locally. Aggregate filters and aggregate orders aren't pushed down as MySQL doesn't support them.
See also:
For more information, see Example: Aggregate pushdown Also, see Blog: Aggregate Pushdown - covers performance improvements, using join and aggregate pushdowns together, and pushing down aggregates to the partition table
ORDER BY pushdown
MySQL Foreign Data Wrapper supports ORDER BY pushdown. If possible, push ORDER BY clause to the remote server so that we get the ordered result set from the foreign server itself. It might help us to have an efficient merge join. NULLs behavior is opposite on the MySQL server. Thus to get an equivalent result, we add the "expression IS NULL" clause at the beginning of each of the ORDER BY expressions.
For more information, see Example: ORDER BY pushdown
LIMIT OFFSET pushdown
MySQL Foreign Data Wrapper supports limit offset push-down. Wherever possible, perform LIMIT
and OFFSET
operations on the remote server. This reduces network traffic between local PostgreSQL and remote MySQL servers. ALL/NULL
options are not supported on the MySQL server, and thus they are not pushed down. Also, OFFSET
without LIMIT
is not supported on the MySQL server hence queries having that construct are not pushed.
For more information, see Example: LIMIT OFFSET pushdown
Configuration file to restrict pushdowns
MySQL 2.9.0 and later provides the mysql_fdw_pushdown.config
configuration file to restrict the pushdowns. You can define the list of functions and operators in this file that can pushdown to the remote server. You can easily add or modify the list as per the requirements.
This file lists the objects as aggregates, functions, and operators allowed to push down to the remote server. Each entry should be on a single line. Each entry must have two columns:
- Object type that can be ROUTINE (functions, aggregates, and procedures) or OPERATOR
- The second column is the schema-qualified object names with their arguments
The exact form of the second column can be formatted using the following query:
For ROUTINE:
For OPERATOR:
Example of mysql_fdw_pushdown.config
file:
Using a connection file
MySQL Foreign Data Wrapper 2.9.2 and later provides the MYSQL_DEFAULT_FILE
option to read the connection details from the default file. You can provide the filename using this option with connection details like username, password, etc. Set the MYSQL_DEFAULT_FILE
option at a server level to the default connection file name. If this option is set to a wrong filename or the file contents are not in the required format, then an error is raised.
If MYSQL_DEFAULT_FILE
and the other connection details both are provided in the CREATE SERVER/USER MAPPING command, then MYSQL_DEFAULT_FILE
option takes the precedence.
For more information, see Example: Using a connection file
IS [NOT] DISTINCT FROM operator
MySQL Foreign Data Wrapper 2.9.0 and later supports the IS [NOT] DISTINCT FROM
operator. MySQL uses the <=>
operator corresponding to the IS NOT DISTINCT FROM
operator and the NOT <=>
operator corresponding to the IS DISTINCT FROM
operator.
Prepared Statement
MySQL Foreign Data Wrapper supports Prepared Statement. The select queries use prepared statements instead of simple query protocol.
Import foreign schema
MySQL Foreign Data Wrapper supports import foreign schema, which enables the local host to import table definitions to EDB Postgres Advanced Server from the MySQL server. The new foreign tables are created with the corresponding column types and same table name as the remote tables in the existing local schema. From version 2.9.0 and later, it supports the import_generated
option to include columns generated from expressions in the definitions of foreign tables imported from a foreign server.
For more information, see Example: Import foreign schema for an example.
Automated cleanup
MySQL Foreign Data Wrapper allows the cleanup of foreign tables in a single operation using the DROP EXTENSION
command. This feature is useful when a foreign table is set for a temporary purpose. The syntax is:
DROP EXTENSION mysql_fdw CASCADE;
For more information, see DROP EXTENSION.
Truncate table
From version 2.9.0 and later, MySQL Foreign Data Wrapper supports the TRUNCATE TABLE
command on the foreign tables. However, the CASCADE
option isn't supported with the TRUNCATE TABLE
command.
- On this page
- Writable foreign data wrapper
- Connection pooling
- WHERE clause pushdown
- Column pushdown
- Join pushdown
- Aggregate pushdown
- ORDER BY pushdown
- LIMIT OFFSET pushdown
- Configuration file to restrict pushdowns
- Using a connection file
- IS NOT DISTINCT FROM operator
- Prepared Statement
- Import foreign schema
- Automated cleanup
- Truncate table