要修改一个表,表必须包含在您的模式中,或者您必须具有该表的ALTER对象权限或ALTER ANY TABLE系统权限。 KingbaseES提供了一族命令来对已有的表进行修改。通过更改表,用户可以对数据库中的表作如下修改:
1、增加列
ALTER TABLE products ADD COLUMN description text;
2、删除列
ALTER TABLE products DROP COLUMN description;
列中的数据将会消失,涉及到该列的表约束也会被移除。然而,如果该列被另一个表的外键所引用,KingbaseES不会移除该约束。我们可以通过增加CASCADE来授权移除任何依赖于被删除列的所有东西:
ALTER TABLE products DROP COLUMN description CASCADE;
3、列增加约束
在现有表基础上新增加约束,可以使用表约束的语法,例如:
ALTER TABLE products ADD CHECK (name <> '');ALTER TABLE products ADD CONSTRAINT some_name UNIQUE (product_no);ALTER TABLE products ADD FOREIGN KEY (product_group_id) REFERENCES product_groups;
要增加一个不能写成表约束的非空约束,可使用语法:
ALTER TABLE products ALTER COLUMN product_no SET NOT NULL;
该约束会立即被检查,所以表中的数据必须在约束被增加之前就已经符合约束
4、删除约束
为了移除一个约束首先需要知道它的名称。如果在创建时已经给它指定了名称,那么事情就变得很容易。否则约束的名称由系统生成,我们必须先找出这个名称。ksql的命令d表名将会对此有所帮助,其他接口也会提供方法来查看表的细节。因此命令是:
ALTER TABLE products DROP CONSTRAINT some_name;
5、修改列的默认值
要为一个列设置一个新默认值,使用命令:
ALTER TABLE products ALTER COLUMN price SET DEFAULT 7.77;
注意这不会影响任何表中已经存在的行,它只是为未来的INSERT命令改变了默认值。 要移除任何默认值,使用:
ALTER TABLE products ALTER COLUMN price DROP DEFAULT;
这等同于将默认值设置为空值。相应的,试图删除一个未被定义的默认值并不会引发错误,因为默认值已经被隐式地设置为空值。
6、修改列类型
为了将一个列转换为一种不同的数据类型,使用如下命令:
ALTER TABLE products ALTER COLUMN price TYPE numeric(10,2);
只有当列中的每一个项都能通过一个隐式造型转换为新的类型时该操作才能成功。如果需要一种更复杂的转换,应该加上一个USING子句来指定应该如何把旧值转换为新值。
KingbaseES将尝试把列的默认值转换为新类型,其他涉及到该列的任何约束也是一样。但是这些转换可能失败或者产生奇特的结果。因此最好在修改类型之前先删除该列上所有的约束,然后在修改完类型后重新加上相应修改过的约束。
7、重命名列名
ALTER TABLE products RENAME COLUMN product_no TO product_number;
8、重命名表名
ALTER TABLE products_table RENAME TO products_items;