使用 ALTER TABLE 語句:
創(chuàng)新互聯(lián)公司長期為成百上千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為雨城企業(yè)提供專業(yè)的網(wǎng)站設(shè)計、網(wǎng)站建設(shè),雨城網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
增加字段
修改字段
修改字段默認(rèn)值
刪除字段
1、增加字段,新字段將成為最后一列:
alter table table
add (column datatype [default expr]
[, column datatype]...);
alter table dept80 add (job_id varchar2(9));
2、修改字段的數(shù)據(jù)類型、大小和默認(rèn)值(修改后的默認(rèn)值只影響修改后插入表中的數(shù)據(jù))
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 選項標(biāo)記一個或多個字段為不可用。
您可以使用 DROP UNUSED COLUMNS 刪除標(biāo)記為不可用的字段。
alter table
set unused(
或
alter table
set unused column
alter table
管理約束
增加約束語法
使用 ALTER TABLE 語句:
添加或刪除約束,不會修改其結(jié)構(gòu)
啟用和禁用約束
通過使用 MODIFY 子句添加 NOT NULL 約束
語法:
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 約束,前提是父節(jié)點(diǎn)
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 子句級聯(lián)刪除:
alter table emp2 add constraint emp_dt_fk
foreign key (department_id)
references departments(department_id) on delete cascade;
使用 ON DELETE SET NULL 當(dāng)父節(jié)點(diǎn)記錄刪除時子節(jié)點(diǎn)
記錄置空:
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 的區(qū)別
INITIALLY DEFERRED | 事務(wù)結(jié)束后驗證 |
INITIALLY IMMEDIATE | 語句執(zhí)行時立即驗證 |
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 約束并刪除相關(guān)聯(lián)的FOREIGN KEY約束:
alter table dept2 drop primary key cascade;
禁用約束
使用 ALTER TABLE 語句的 DISABLE 子句禁用完整性約束
應(yīng)用 CASCADE 選項禁用相關(guān)的完整性約束
alter table emp2 disable constraint emp_dt_fk;
啟用約束
使用 ENABLE 子句激活當(dāng)前禁用表中定義的完整性約束。
alter table emp2 enable constraint emp_dt_fk;
如果啟用了唯一鍵或主鍵約束,會自動創(chuàng)建一個唯一索引
級聯(lián)約束
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 總結(jié)
刪除用戶的時候級聯(lián)刪除對象
drop user test cascade;
刪表時級聯(lián)刪除約束
drop table test cascade constraints;
刪字段的時候,級聯(lián)刪除約束(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;