Oracle基础 11 约束 constraints


--主、外键约束

create table t(
  id int primary key);


create table t1(

  id int references t(id));

或者

create table t(
id int constraint pk_t_id primary key);


create table t1(

id int constraint fk_t1_id references t(id));

 
修改列为主、外键约束

  create table emp1(
    id number(10),
    name varchar2(20),
    dept number(10)
  );
  create table dept1(
    dept number(10),
    dept_name varchar2(20)
  );

  alter table dept1
  add constraint pk_dept1_dept primary key(dept);

  alter table emp1
  add constraint fk_emp1_dept foreign key(dept) references dept1(dept);

 

--创建非空约束列

  create table t(      
    id number(10) constraint nn_t_id not null,
    name varchar2(20),
    company varchar2(20)
  );

  修改列为非空约束

  create table t(
    id number(10),
    name varchar2(20),
    company varchar2(20)
  );
  alter table t
  modify id constraint nn_t_id not null; 


--创建唯一约束列

  create table t(                                           
    id number(10) constraint u_t_i unique,
    name varchar2(20),
    company varchar2(20)
  );

  修改列为唯一约束
  alter table t
  add constraint u_t_id unique(id);


--创建检查约束

  create table aa3(       
    id number(10) constraint aa3_id_c check(id>=101),
    name varchar2(20),
    company varchar2(20)
  );

  修改列为检查约束
  create table t2(
    id int);
  alter table t2
  add constraint c_t2_id check(id>100);


--删除约束

  alter table t2 drop constraint c_t2_id; 
 
注意:对于外键约束的删除时有顺序的,要不然会提示,找到子记录的信息。先删子表的约束,再删父表的约束。 
 
--查看约束 

在oracle中,可以通过 user_constraints 视图来查找。
 
select table_name,constraint_name,constraint_type
from user_constraints
where table_name='大写的表名'
 
注意:oracle中约束是一用户名为指定范围存放的。也就是说一个用户名下面约束名子不能有重复,但整个数据库中,可以有相同的约束名。


 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/27633655/viewspace-1080355/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/27633655/viewspace-1080355/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值