用户登录
用户注册

分享至

impala alter table

  • 作者: 郴州0勃大径深
  • 来源: 51数据库
  • 2020-10-03

Alter table,网络程序及编程中所用的术语。通过更改、添加、除去列和约束,或者通过启用或禁用约束和触发器来更改表的定义。


要使用 ALTER TABLE,你必需拥有该表; 除了 ALTER TABLE OWNER 之外,它只能由超级用户执行。


例子  向表中增加一个 varchar 列:



  ALTER TABLE distributors ADD address varchar(30);



  从表中删除一个字段:



  ALTER TABLE distributors DROP COLUMN address RESTRICT;



  在一个操作中修改两个现有字段的类型:



  ALTER TABLE distributors



  ALTER COLUMN address TYPE varchar(80),



  ALTER COLUMN name TYPE varchar(100);



  使用一个 USING 子句, 把一个包含 UNIX 时间戳的 integer 字段转化成 timestamp with time zone:



  ALTER TABLE foo



  ALTER COLUMN foo_timestamp TYPE timestamp with time zone



  USING



  timestamp with time zone 'epoch' + foo_timestamp * interval '1 second';



  对现存字段改名:



  ALTER TABLE distributors RENAME COLUMN address TO city;



  更改现存表的名字:



  ALTER TABLE distributors RENAME TO suppliers;



  给一个字段增加一个非空约束:



  ALTER TABLE distributors ALTER COLUMN street SET NOT NULL;



  从一个字段里删除一个非空约束:



  ALTER TABLE distributors ALTER COLUMN street DROP NOT NULL;



  给一个表增加一个检查约束:



  ALTER TABLE distributors ADD CONSTRAINT zipchk CHECK (char_length(zipcode) = 5);



  删除一个表和它的所有子表的监查约束:



  ALTER TABLE distributors DROP CONSTRAINT zipchk;



  向表中增加一个外键约束:



  ALTER TABLE distributors ADD CONSTRAINT distfk FOREIGN KEY (address) REFERENCES addresses(address) MATCH FULL;



  给表增加一个(多字段)唯一约束:



  ALTER TABLE distributors ADD CONSTRAINT dist_id_zipcode_key UNIQUE (dist_id, zipcode);



  给一个表增加一个自动命名的主键约束,要注意的是一个表只能有一个主键:



  ALTER TABLE distributors ADD PRIMARY KEY (dist_id);



  把表移动到另外一个表空间:



  ALTER TABLE distributors SET TABLESPACE fasttablespace;

软件
前端设计
程序设计
Java相关