This is a post on how to create a Linked Server to a PostgreSQL database.
In my previous post, I created a Linked Server to another SQL Server instance. This time, it’s a link to a Postgres database. I recommend checking out my other post for pre-requisite information including testing connectivity to the remote database server.
Follow these steps to create a Linked Server to a Postgres server:
1. Create Linked Server Login on Postgres.
2. Install the Postgres ODBC Driver.
3. Configure ODBC Data Source Settings.
4. Create Linked Server to a Postgres Database.
1. Create Linked Server Login on Postgres
We first need to create a login for the Linked Server on Postgres:
data:image/s3,"s3://crabby-images/60c47/60c47520d440387efa55f94fdf879af27eb9d0fc" alt="Postgres Create New User"
For this example I’m making the user in Postgres a Superuser. This is not ideal, we should be configuring it with the least permissions it requires. This is just a demo though.
data:image/s3,"s3://crabby-images/5413a/5413abd1eb35f1530d1041936eeb59a614101acc" alt="Postgres User Options"
For demo purposes, I’m also showing how this would be done using a terminal:
data:image/s3,"s3://crabby-images/92d96/92d967da24254bac85d09d12033ecd1900169e20" alt="psql Create and View Users"
2. Install Postgres ODBC Driver
The ODBC driver must be installed on both ends. This step is a reminder to ensure you have this installed.
You can use Stack Builder to install it, or download the Postgres ODBC driver package on its own:
data:image/s3,"s3://crabby-images/023ec/023ecaae7fbef7af1e9193f7c17eafa2e2f740b0" alt="Postgres ODBC Driver Download"
We need to install this:
data:image/s3,"s3://crabby-images/2a088/2a08859ceba5ecd9f652e2a63698b96b61d06958" alt="psqlODBC Setup Wizard"
Accept License stuff.
Specify directory & we don’t need the documentation.
data:image/s3,"s3://crabby-images/ea469/ea469028d58286c2e012555d68ec1d95525595a1" alt="psqlODBC Feature Selection"
It’s a straight-forward install:
data:image/s3,"s3://crabby-images/b6175/b6175891a379a0dfb7b5202e9ea5d25074a38879" alt="psqlODBC Install Wizard"
3. Configure ODBC Data Source Settings
On our SQL Server, we need to configure the ODBC driver for the Postgres database.
To do this, open ODBC Data Sources as Administrator:
data:image/s3,"s3://crabby-images/22106/221066e6a31207871dffaa6e3f20e5689fe07176" alt="Run ODBC Source as Administrator"
Click the System DSN tab and click Add.
data:image/s3,"s3://crabby-images/28b13/28b135909fdce2086cd9e3e30a3dbd46c0b312e1" alt="ODBC Data Source System DSN"
Select the PostgreSQL Unicode driver:
data:image/s3,"s3://crabby-images/23b42/23b428c2379881828682af70fa31aee2dbd6c83b" alt="Create New Postgres ODBC Data Source"
Enter all details required, In this example I created a ‘sales’ database which I’m connecting to:
data:image/s3,"s3://crabby-images/7193e/7193ed8aeaae2500f903b8104a49564a318d6dee" alt="ODBC Data Source Settings for Postgres"
Finally, we should test the connection to verify all is good:
data:image/s3,"s3://crabby-images/7ebeb/7ebeb9b5c9196c9515b0ec3ee0ad30e193c34a4f" alt="ODBC Test Connection"
4. Create Linked Server to a Postgres Database
To create a Linked Server to Postgres:
1. Expand Server Objects, right-click Linked Servers and select New Linked Server.
data:image/s3,"s3://crabby-images/4dba4/4dba42bf6b9ef4b259a168a9860f00006e9915a6" alt="SSMS New Linked Server"
2. The New Linked Server Wizard will prompt.
Configure your settings, choose a provider for ODBC, entering the correct Data Source Name which you entered within the ODBC driver settings above in this post.
data:image/s3,"s3://crabby-images/16c9e/16c9eeea1f33f44bd20885eb4f8dec25b754b6ec" alt="SSMS New Linked Server Postgres"
3. Enter the Postgres Login Details as created above within this post in the Security tab.
data:image/s3,"s3://crabby-images/6b895/6b895db0fce9cb1ea26defdec7846ef7c800a5f6" alt="SSMS Linked Server Login Details"
4. We can skip the Server Options tab and hit OK.
5. Next, we should test the Linked Server connection.
data:image/s3,"s3://crabby-images/b2ed1/b2ed17143089ca0f3bdb7d003a853c7de7d3fdbb" alt="SSMS Test Linked Server Connection"
It should show this:
data:image/s3,"s3://crabby-images/75895/7589506feef3e2d87c47268164864252a852d26c" alt="Linked Server Connection Test"
We can now verify the Linked Server is working as it should by running the following query:
-- linked server query example select * from [linked-server-name].[database-name].[schema-name].[table-name];
data:image/s3,"s3://crabby-images/ae393/ae3935e8190efc9d2baccfaa6f704b62b988bc03" alt="Linked Server Query with Postgres"
I hope this was a good and useful post for you. Feel free to check out the links you see around here for more random useful info from a random database guy!
Leave a Reply