400 028 6601

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

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

使用 ALTER TABLE 语句:

创新互联公司长期为成百上千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为雨城企业提供专业的网站设计、网站建设雨城网站改版等技术服务。拥有十载丰富建站经验和众多成功案例,为您定制开发。

1、增加字段,新字段将成为最后一列:

alter table table

add (column datatype [default expr]

[, column datatype]...);

alter table dept80 add (job_id varchar2(9));

2、修改字段的数据类型、大小和默认值(修改后的默认值只影响修改后插入表中的数据)

alter table table

modify (column datatype [default expr]

[, 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 选项

alter table

set unused( [ ,  ] );

alter table

set unused column  [ , ] ;

alter table drop unused columns;

管理约束

增加约束语法

使用 ALTER TABLE 语句:

语法:

alter table

add [constraint ]

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_pk  primary 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;

禁用约束

 alter table emp2 disable constraint emp_dt_fk;

启用约束

使用 ENABLE 子句激活当前禁用表中定义的完整性约束。

 alter table emp2 enable constraint emp_dt_fk;

如果启用了唯一键或主键约束,会自动创建一个唯一索引

级联约束

示例:

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;

alter table test drop column (id) cascade constraints;

alter table test disable constraint pk_test cascade;

重命名表的列和约束

1、使用 RENAME COLUMN子句的ALTER TABLE语句来重新命名表列。

 alter table marketing rename column team_id to id;

2、使用RENAME CONSTRAINT子句的ALTER TABLE语句来重命名表中任意已存在的约束。

 alter table marketing rename constraint mktg_pk to new_mktg_pk;


本文名称:SQL基础之管理方案对象(十七)
新闻来源:http://mzwzsj.com/article/gojpsj.html

其他资讯

让你的专属顾问为你服务