返回顶部
首页 > 资讯 > 数据库 >SQL 基础之管理方案对象(十七)
  • 435
分享到

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

2024-04-02 19:04:59 435人浏览 安东尼
摘要

使用 ALTER TABLE 语句: 增加字段 修改字段 修改字段默认值 删除字段1、增加字段,新字段将成为最后一列:alter table tableadd (co

使用 ALTER TABLE 语句:

  •  增加字段

  •  修改字段

  •  修改字段默认值

  •  删除字段


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

  • 您可以使用 SET UNUSED 选项标记一个或多个字段为不可用。

  • 您可以使用 DROP UNUSED COLUMNS 删除标记为不可用的字段。


alter table <table_name>

set unused(<column_name> [ ,  <column_name>] );

alter table <table_name>

set unused column <column_name>  [ , <column_name>] ;


alter table <table_name> drop unused columns;


管理约束

增加约束语法

使用 ALTER TABLE 语句:

  •  添加或删除约束,不会修改其结构

  •  启用和禁用约束

  •  通过使用 MODIFY 子句添加 NOT NULL 约束

语法:

alter table <table_name>

add [constraint <constraint_name>]

type (<column_name>);


添加约束

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 语句的 DISABLE 子句禁用完整性约束

  • 应用 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 id;


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

 alter table marketing rename constraint mktg_pk to new_mktg_pk;

您可能感兴趣的文档:

--结束END--

本文标题: SQL 基础之管理方案对象(十七)

本文链接: https://lsjlt.com/news/43231.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作