PostgreSQL ALTER TABLE 命令用于添加,删除或修改现有表中的列.
您还可以使用ALTER TABLE命令添加和删除现有表上的各种约束.
语法
ALTER TABLE 的基本语法,用于添加新列现有表如下 :
ALTER TABLE table_name ADD column_name datatype;
现有表格中ALTER TABLE到 DROP COLUMN 的基本语法如下 :
ALTER TABLE table_name DROP COLUMN column_name;
用于更改表中列的 DATA TYPE 的ALTER TABLE的基本语法如下 :
ALTER TABLE table_name ALTER COLUMN column_name TYPE datatype;
ALTER TABLE的基本语法是将 NOT NULL 约束添加到表中的列,如下所示 :
ALTER TABLE table_name MODIFY column_name datatype NOT NULL;
ALTER TABLE到 ADD UNIQUE CONSTRAINT 到表的基本语法如下 :
ALTER TABLE table_name ADD CONSTRAINT MyUniqueConstraint UNIQUE(column1,column2 ...);
ALTER TABLE到 ADD CHECK CONSTRAINT 到表的基本语法如下 :
ALTER TABLE table_name ADD CONSTRAINT MyUniqueConstraint CHECK(CONDITION);
对表格的ALTER TABLE到 ADD PRIMARY KEY 约束的基本语法如下 :
ALTER TABLE table_name ADD CONSTRAINT MyPrimaryKey PRIMARY KEY(column1,column2 ...);
表中ALTER TABLE到 DROP CONSTRAINT 的基本语法如下 :
ALTER TABLE table_name DROP CONSTRAINT MyUniqueConstraint;
如果你使用MySQL,代码如下 :
ALTER TABLE table_name DROP INDEX MyUniqueConstraint;
表中ALTER TABLE到 DROP PRIMARY KEY 约束的基本语法如下 :
ALTER TABLE table_name DROP CONSTRAINT MyPrimaryKey;
如果你使用MySQL,代码如下 :
ALTER TABLE table_name DROP PRIMARY KEY;
示例
考虑我们的公司表具有以下记录 :
id | name | age | address | salary----+-------+-----+-----------+-------- 1 | Paul | 32 | California| 20000 2 | Allen | 25 | Texas | 15000 3 | Teddy | 23 | Norway | 20000 4 | Mark | 25 | Rich-Mond | 65000 5 | David | 27 | Texas | 85000 6 | Kim | 22 | South-Hall| 45000 7 | James | 24 | Houston | 10000
以下是在现有表中添加新列的示例 :
testdb =#ALTER TABLE COMPANY ADD GENDER char(1);
现在,COMPANY表被更改,以下将是SELECT语句的输出 :
id | name | age | address | salary | gender----+-------+-----+-------------+--------+-------- 1 | Paul | 32 | California | 20000 | 2 | Allen | 25 | Texas | 15000 | 3 | Teddy | 23 | Norway | 20000 | 4 | Mark | 25 | Rich-Mond | 65000 | 5 | David | 27 | Texas | 85000 | 6 | Kim | 22 | South-Hall | 45000 | 7 | James | 24 | Houston | 10000 |(7 rows)
以下是现有表格中DROP性别列的示例 :
testdb =#ALTER TABLE COMPANY DROP GENDER;
现在,COMPANY表被更改,以下将是SELECT语句的输出 :
id | name | age | address | salary----+-------+-----+-----------+-------- 1 | Paul | 32 | California| 20000 2 | Allen | 25 | Texas | 15000 3 | Teddy | 23 | Norway | 20000 4 | Mark | 25 | Rich-Mond | 65000 5 | David | 27 | Texas | 85000 6 | Kim | 22 | South-Hall| 45000 7 | James | 24 | Houston | 10000