Postgresql中如何给表添加新列

 时间:2026-02-13 11:30:00

1、Postgresql自带工具psql连接数据库 psql -Upostgres -h 127.0.0.1 pg_test_db(我们这里使用自带用户postgres, 数据库安装在本机127.0.0.1)

Postgresql中如何给表添加新列

2、创建schema:pg_test_db=# create schema schema_a, 创建表 pg_test_db=# create table schema_a.table_a(id int, name varchar);

Postgresql中如何给表添加新列

3、现在我们要添加descr列。由于我们的脚本必须能够允许多次运行,所以再添加列的时候必须判断表中是否descr已经存在。Postgresql中information_schema.columns包含所有表的列信息。

Postgresql中如何给表添加新列

Postgresql中如何给表添加新列

4、脚本内容:

DO language plpgsql $$

BEGIN

    RAISE INFO '*************** test_add_column.sql begins'' ***************';

    if not exists (select 1 from information_schema.columns where table_schema = 'schema_a'  

        and table_name = 'table_a' 

        and column_name = 'descr')

    then

        alter table schema_a.table_a add column descr varchar;

    end if;

    RAISE INFO '*************** test_add_column.sql completes'' ***************';

    EXCEPTION

      WHEN OTHERS THEN

        RAISE NOTICE '*************** Patch ''test_add_column.sql'' fails : ErrCode (%) (%)', SQLSTATE, SQLERRM;

        RAISE;

END;

$$;

保存为 /home/kian.gao/Desktop/test_add_column.sql

5、在psql中使用 \i /home/kian.gao/Desktop/test_add_column.sql 命令执行该sql文件即可, 多次运行也不会报错,如果没有事先判断多次运行就会报错,因为该列已经存在。

Postgresql中如何给表添加新列

6、希望能对Postgresql初学者有所帮助!

  • Xshell如何同时向多个会话、连接发出指令
  • 如何使用gitlab查看项目列表
  • K662c如何查找设备并设定静态地址
  • Xshell怎么开启双击选项卡复制ssh通道功能
  • VMware workstation虚拟机与真机之间复制文件
  • 热门搜索
    文明出行手抄报内容 中国神话故事手抄报 数学手抄报内容大全 缅怀先烈手抄报资料 初中安全手抄报 关于英雄的手抄报图片 国学经典手抄报图片 三爱三节手抄报图片 防火手抄报图片大全 绿色校园手抄报内容