广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    Postgresql中如何给表添加新列

    来源:网络收集  点击:  时间:2024-03-04
    【导读】:
    在软件开发和维护过程中由于需求变动或者新需求,经常需要在PostgreSQL数据库中表中添加新列,而且要确保增量脚本能被多次运行而不出现错误。本篇经验告诉各位如何正确的添加新列。工具/原料morepostgresql,computer方法/步骤1/6分步阅读

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

    2/6

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

    3/6

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

    4/6

    脚本内容:

    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/6

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

    6/6

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

    注意事项

    如果认为本经验对您有所帮助,请点击下面【投票】支持一下小编!如果您想以后随时浏览请点击下面的【收藏】,如果您认为本经验能够帮助到您的朋友,请点击页面右下方的双箭头进行分享。

    编程语言POSTGRESQL添加列表SQL
    本文关键词:

    版权声明:

    1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

    2、本站仅提供信息发布平台,不承担相关法律责任。

    3、若侵犯您的版权或隐私,请联系本站管理员删除。

    4、文章链接:http://www.1haoku.cn/art_238795.html

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-05 11:41:31  耗时:0.030
    0.0297s