PostgreSQL Tutorial: RENAME COLUMN: Renaming a column

August 2, 2023

Summary: in this tutorial, you will learn how to use the PostgreSQL RENAME COLUMN clause in the ALTER TABLE statement to rename one or more columns of a table.

PostgreSQL RENAME COLUMN

Table of Contents

Introduction to PostgreSQL RENAME COLUMN clause

To rename a column of a table, you use the ALTER TABLE statement with RENAME COLUMN clause as follows:

ALTER TABLE table_name 
RENAME COLUMN column_name TO new_column_name;

In this statement:

  • First, specify the name of the table that contains the column which you want to rename after the ALTER TABLE clause.
  • Second, provide name of the column that you want to rename after the RENAME COLUMN keywords.
  • Third, specify the new name for the column after the TO keyword.

The COLUMN keyword in the statement is optional therefore you can omit it like this:

ALTER TABLE table_name 
RENAME column_name TO new_column_name;

For some reason, if you try to rename a column that does not exist, PostgreSQL will issue an error. Unfortunately that PostgreSQL does not provide the IF EXISTS option for the RENAME clause.

To rename multiple columns, you need to execute the ALTER TABLE RENAME COLUMN statement multiple times, one column at a time:

ALTER TABLE table_name
RENAME column_name1 TO new_column_name1;

ALTER TABLE table_name
RENAME column_name2 TO new_column_name2;

If you rename a column referenced by other database objects such as views, foreign key constraints, triggers, and stored procedures, PostgreSQL will automatically change the column name in the dependent objects.

PostgreSQL RENAME COLUMN examples

Let’s take some examples of using the ALTER TABLE RENAME COLUMN to get a better understanding.

Setting the sample tables

First, create two new tables customers and customer_groups.

CREATE TABLE customer_groups (
    id serial PRIMARY KEY,
    name VARCHAR NOT NULL
);

CREATE TABLE customers (
    id serial PRIMARY KEY,
    name VARCHAR NOT NULL,
    phone VARCHAR NOT NULL,
    email VARCHAR,
    group_id INT,
    FOREIGN KEY (group_id) REFERENCES customer_groups (id)
);

Then, create a new view named customer_data based on the customers and customer_groups tables.

CREATE VIEW customer_data 
AS SELECT
    c.id,
    c.name,
    g.name customer_group
FROM
    customers c
INNER JOIN customer_groups g ON g.id = c.group_id;

1) Using RENAME COLUMN to rename one column example

The following statement uses the ALTER TABLE RENAME COLUMN statement to rename the email column of the customers table to contact_email:

ALTER TABLE customers 
RENAME COLUMN email TO contact_email;

2) Using RENAME COLUMN to rename a column that has dependent objects example

This example uses the ALTER TABLE RENAME COLUMN statement to rename the name column of the customer_groups table to group_name. The name column is used in the customer_data view.

ALTER TABLE customer_groups 
RENAME COLUMN name TO group_name;

Now, you can check whether the change of the name column was cascaded to the customer_data view:

test=# \d+ customer_data;
                       View "public.customer_data"
     Column     |       Type        | Modifiers | Storage  | Description
----------------+-------------------+-----------+----------+-------------
 id             | integer           |           | plain    |
 name           | character varying |           | extended |
 customer_group | character varying |           | extended |
View definition:
 SELECT c.id,
    c.name,
    g.group_name AS customer_group
   FROM customers c
     JOIN customer_groups g ON g.id = c.group_id;

As you can see in the view definition, the name column has been changed to group_name.

3) Using multiple RENAME COLUMN to rename multiple columns example

These statements rename two columns name and phone of the customers table to customer_name and contact_phone respectively:

ALTER TABLE customers 
RENAME COLUMN name TO customer_name;

ALTER TABLE customers
RENAME COLUMN phone TO contact_phone;

In this tutorial, you have learned how to use the PostgreSQL RENAME COLUMN clause in the ALTER TABLE statement to rename a column.