Home > Documentation > MySQL to PostgreSQL
Migrate MySQL to PostgreSQL |
[MySQL to PostgreSQL Converter] [How to Control Migration Results] [Types Mapping] [Converting Queries] |
Both MySQL and PostgreSQL are popular open-source RDBMS enriched by wide range of administration and development tools. Both systems are ported on every popular OS and have large communities of experts. However, PostgreSQL provides multiple advantages that may be important for certain projects:
On the other hand, PostgreSQL is more complex than MySQL and it can be difficult for beginners. So, if you work on simple database project that is covered by MySQL capabilities and do not plan to scale it, there is no much sense to migrate it from MySQL to Postgres.
1. Manual Migration. The steps described below are required to migrate database from MySQL to PostgreSQL manually:
phpMyAdmin - highlight the table, go to 'Export' tab, select 'Custom' option, set format to 'SQL' and make sure that radio-button 'Structure' is selected
MySQL console client - use the statement
mysqldump -d -h (host) -u (user) -p(password) (databasename) > (dumpifle)All patterns in round brackets must be replaced by actual values
phpMyAdmin - highlight the table, go to 'Export' tab, select 'Custom' option, set format to 'CSV' and make sure that radio-button 'Data' is selected
MySQL console client - use the statement
SELECT * INTO OUTFILE ('table.csv') FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\n' FROM (table)All patterns in round brackets must be replaced by actual values
views
SELECT table_name, view_definition FROM information_schema.views WHERE table_schema='(your database name)'stored procedures
SHOW PROCEDURE STATUS WHERE Db = 'your database name'triggers
SHOW TRIGGERS
2. Pgloader. Pgloader is a migration tool that facilitates the transfer of data from MySQL, SQLite and MS SQL Server to PostgreSQL. It is free and needs the following prerequisites:
As soon as you fulfill all these requirements, Pgloader can be installed from the Ubuntu APT repositories using the apt command. However, in order to use the useSSL option in v3.5.1 and later, it is necessary to install from the source code that can be obtained from the GitHub repository.
After the installation of Pgloader succeeds, the database migration procedure containing the following steps may be started:
If a role authenticates using the same method and name as the Linux user profile that run the tool, Pgloader can upload data into a PostgreSQL database using that role. This whitepaper explores how to create a PostgreSQL role with password authentication and generate a target database for loading the source data.
0000-00-00 00:00:00
datetime values.
Those values must be replaced by 1970-01-01 00:00:00
, so that
PostgreSQL could accept it.
$ pgloader mysql://mysql_username:password@mysql_host/source_database_name? useSSL=true postgresql:// postgresql://postgresql_role_name:password@postgres_host/target_database_name ?option_1=value&option_n=value
3. Connect MySQL to PostgreSQL Using Foreign Data Wrapper.
This method is based on the PostgreSQL foreign data wrapper feature and includes the following steps.
CREATE EXTENSION
command. It's crucial to ensure that
there are no previously loaded extensions with the same name. The CREATE EXTENSION
command generates new SQL objects like operators, data types, functions, and index
support methods. The user who executes the CREATE EXTENSION
command becomes
the owner of the newly created extension.
To establish a connection between PostgreSQL and MySQL, you must create the mysql_fdw extension. To achieve this, you need to input mysql_fdw as the extension_name while creating the extension. This allows you to query the MySQL server from the Postgres database:
CREATE EXTENSION [IF NOT EXISTS] extension_name [WITH] [SCHEMA schema_name];
CREATE SERVER
command, you can
create a new foreign server and establish its connections. This command provides
the necessary connection information that Foreign Data Wrapper requires to access
external data sources.
The user who creates the server becomes its owner, and it's mandatory to ensure that the server's name is unique within the database:
CREATE SERVER [ IF NOT EXISTS ] server_name[TYPE server_type] FOREIGN DATA WRAPPER fdw_name [OPTIONS (option 'value' [, ...] ) ]
CREATE USER MAPPING [ IF NOT EXISTS ] FOR { user_name | USER | CURRENT_USER | PUBLIC } SERVER server_name [OPTIONS ( option 'value' [, ...] ) ]
CREATE FOREIGN TABLE [ IF NOT EXISTS ] table_name( [ { column_name data_type [ OPTIONS ( option 'value' [, ... ] ) ] [ COLLATE collation] [ column_constraint[ ... ] ] | table_constraint } [, ... ] ] ) [ INHERITS ( parent_table [, ... ] ) ] SERVER server_name [ OPTIONS ( option 'value' [, ... ] ) ]
As example, assume we have MySQL table with the following structure:
CREATE TABLE Persons ( PersonID int, LastName varchar(255), FirstName varchar(255), Address varchar(255), City varchar(255) );Then we need to execute the following statement to create equivalent table in the PostgreSQL database:
CREATE FOREIGN TABLE Persons ( PersonID int, LastName varchar(255), FirstName varchar(255), Address varchar(255), City varchar(255) ) SERVER mysql_server OPTIONS (dbname 'db name', table_name 'Persons');
Usually, IMPORT FOREIGN SCHEMA
imports all the views and tables present
in a specific schema on the foreign server. However, it's possible
to specify a list of tables limited to a subset or exclude certain tables.
IMPORT FOREIGN SCHEMA remote_schema [ { LIMIT TO | EXCEPT } ( table_name [, ...] ) ] FROM SERVER server_name INTO local_schema [ OPTIONS ( option 'value' [, ... ] ) ]
4. Commercial Tools. For those who consider the tree previous migration methods too complicated, it is reasonable to use special commercial tools that can fully automate database migration procedure through intuitive graphical interface within just a few button clicks. One of these tools is MySQL to PostgreSQL converter developed by Intelligent Converters. It has all necessary features to handle large and complex database migration projects and does not require users to have deep technical skills to use it.
Have questions? Contact us