如何快速学习:[1]Swift编程语言,Swift,苹果于2014年WWDC(苹果开发者大会)发布的新开发语言,可与Ojective-C*共同运行于MacOS和iOS平台,用于搭建基于苹果平台的应用程......
2023-03-17 276 编程语言
在软件开发和维护过程中由于需求变动或者新需求,经常需要在PostgreSQL数据库中表中添加新列,而且要确保增量脚本能被多次运行而不出现错误。本篇经验告诉各位如何正确的添加新列。
Postgresql自带工具psql连接数据库 psql -Upostgres -h 127.0.0.1 pg_test_db(我们这里使用自带用户postgres, 数据库安装在本机127.0.0.1)
创建schema:pg_test_db=# create schema schema_a,创建表pg_test_db=# create table schema_a.table_a(id int, name varchar);
现在我们要添加descr列。由于我们的脚本必须能够允许多次运行,所以再添加列的时候必须判断表中是否descr已经存在。Postgresql中information_schema.columns包含所有表的列信息。
脚本内容:
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;
;
$$;
保存为/home/kian.gao/Desktop/test_add_column.sql
在psql中使用\i /home/kian.gao/Desktop/test_add_column.sql 命令执行该sql文件即可, 多次运行也不会报错,如果没有事先判断多次运行就会报错,因为该列已经存在。
希望能对Postgresql初学者有所帮助!
以上方法由办公区教程网编辑摘抄自百度经验可供大家参考!
相关文章
如何快速学习:[1]Swift编程语言,Swift,苹果于2014年WWDC(苹果开发者大会)发布的新开发语言,可与Ojective-C*共同运行于MacOS和iOS平台,用于搭建基于苹果平台的应用程......
2023-03-17 276 编程语言
web图表开发工具FineReport:[11]连续分组,数据库表数据是按照时间先后录入的,查询的时候希望按照时间先后,某个字段连续相同的话就合并起来显示,这样的报表可以通过相邻连续分组来实现。......
2023-03-17 502 编程语言