2168575 发表于 2018-10-20 12:05:16

SQL 基础之管理方案对象(十七)

  使用>

[*]  增加字段
[*]  修改字段
[*]  修改字段默认值
[*]  删除字段
  1、增加字段,新字段将成为最后一列:
  alter table table
  add (column datatype
  [, column datatype]...);
  alter table dept80 add (job_id varchar2(9));
  2、修改字段的数据类型、大小和默认值(修改后的默认值只影响修改后插入表中的数据)
  alter table table
  modify (column datatype
  [, column datatype]...);
  alter table dept80 modify (last_name varchar2(30));
  3、删除字段
  alter table table drop (column [, column]..);
  alter table dept80 drop column job_id;
  SET UNUSED 选项

[*]  您可以使用 SET UNUSED 选项标记一个或多个字段为不可用。
[*]  您可以使用 DROP UNUSED COLUMNS 删除标记为不可用的字段。
  alter table
  set unused( [ ,] );
  或
  alter table
  set unused column   [ , ] ;
  alter tabledrop unused columns;
  管理约束
  增加约束语法

  使用>

[*]  添加或删除约束,不会修改其结构
[*]  启用和禁用约束
[*]  通过使用 MODIFY 子句添加 NOT NULL 约束
  语法:
  alter table
  add
  type ();
  添加约束
  Add a FOREIGN KEY constraint to the EMP2 table indicating that a manager must already exist as a valid employee in the EMP2 table.修改表 EMP2 添加 FOREIGN KEY 约束,前提是父节点
  alter table emp2 modify employee_id primary key;
  alter table emp2
  add constraint emp_mgr_fk
  foreign key(manager_id)
  references emp2(employee_id);
  ON DELETE 语句
  使用 ON DELETE CASCADE 子句级联删除:
  alter table emp2 add constraint emp_dt_fk
  foreign key (department_id)
  references departments(department_id) on delete cascade;
  使用 ON DELETE SET NULL 当父节点记录删除时子节点
  记录置空:
  alter table emp2 add constraint emp_dt_fk
  foreign key (department_id)
  references departments(department_id) on delete set null;
  延迟约束
  延迟约束有以下属性:
  deferrable 或 not deferrable
  initially deferred 或 initially immediate
  alter table dept2 add constraint dept2_id_pkprimary key (department_id)
  deferrable initially deferred
  set constraint dept2_id_pk immediate
  alter session set constraints=immediate
  INITIALLY DEFERRED和INITIALLY IMMEDIATE 的区别
INITIALLY DEFERRED事务结束后验证INITIALLY IMMEDIATE语句执行时立即验证  create table emp_new_sal (salary number
  constraint sal_ck
  check (salary > 100)
  deferrable initially immediate,
  bonus number
  constraint bonus_ck
  check (bonus > 0 )
  deferrable initially deferred );
  删除约束
  删除表 EMP2 的 emp_mgr_fk 约束:
  alter table emp2 drop constraint emp_mgr_fk;
  删除DEPT2表的 PRIMARY KEY 约束并删除相关联的FOREIGN KEY约束:
  alter table dept2 drop primary key cascade;
  禁用约束

[*]
  使用>
[*]  应用 CASCADE 选项禁用相关的完整性约束
  alter table emp2 disable constraint emp_dt_fk;
  启用约束
  使用 ENABLE 子句激活当前禁用表中定义的完整性约束。
  alter table emp2 enable constraint emp_dt_fk;
  如果启用了唯一键或主键约束,会自动创建一个唯一索引
  级联约束

[*]  CASCADE CONSTRAINTS 子句在 DROP COLUMN 子句中使用。
[*]  删除字段 CASCADE CONSTRAINTS 指定子句,同时也将删除所有定义的多列约束。
[*]  删除列上定义的 PRIMARY 和 UNIQUE 约束时指定CASCADE CONSTRAINTS 子句,则将删除所有引用它的完整性约束
  示例:
  alter table emp2 drop column employee_id cascade constraints;
  alter table test1 drop (col1_pk, col2_fk, col1) cascade constraints;
  Cascade 总结

[*]  删除用户的时候级联删除对象
  drop user test cascade;

[*]  删表时级联删除约束
  drop table test cascade constraints;

[*]  删字段的时候,级联删除约束(pk,fk,.c)
  alter table test drop column (id) cascade constraints;
  alter table test disable constraint pk_test cascade;

[*]  create table child (c1 number primary key,c2 number references parent(c1) on delete cascade);
  重命名表的列和约束
  1、使用 RENAME COLUMN子句的ALTER TABLE语句来重新命名表列。

  alter table marketing rename column team_id to>  2、使用RENAME CONSTRAINT子句的ALTER TABLE语句来重命名表中任意已存在的约束。
  alter table marketing rename constraint mktg_pk to new_mktg_pk;

页: [1]
查看完整版本: SQL 基础之管理方案对象(十七)