微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Oracle中怎么创建约束

Oracle中怎么创建约束,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

Oracle  创建主键,外键, check约束的几种方法:(write by RFH)

1. 在创建表时创建约束:

//添加主键约束

Create table userinfo (userid number(20)constraint  pk_user  primary key ,uname varchar(20));

Create table userinfo(userid number(20),unamevarchar(20),constraint  pk_user  primary key(userid);

//添加外键约束

create table userinfo(useridnumber(20),deptid number(20)  referencesdept(deptid));

create table userinfo(useridnumber(20),deptid number(20), constraint fk_dept foreign key(deptid)references  dept(deptid));

//添加check约束

create table userinfo(useridnumber(20),age number(3) constraint ck_age check(age<100 and age>10));

create table userinfo(useridnumber(20),age number(3), constraint ck_age check(age<100 and age>10))

2. 假如你已经建表完成,而忘记添加约束,没关系,可以单独添加

   //添加主键约束:

   alter table userinfo add constraintpk_user primary key(userid);

   //添加外键约束:

    alter table userinfo add constraint fk_dept foreign key(deptid)references dept(deptid);

   //添加check约束

   alter table userinfo add constraint ck_age check(age<100 andage>10);

3对表中约束的查询

      Desc userinfo;

all_constraints 包含了表的约束信息,但是会被刷屏

我们用user_constrains表来获取当前用户的约束:

select constraint_name,table_name,constraint_type from  user_constraints;

如果我们要想看某个表的约束:

select constraint_name,table_name,constraint_type from  user_constraints where table_name=’TABLENAME’;//注意表名要大写


类似的,索引表USER_INDEXES,序列表USER_SEQUENCES,触发器表USER_TRIGGERS,存储过程表USER_PROCEDURES,当然还有USER_TABLES,VIEW_TABLES 等。有个惊人的发现,之前建的外键会被添加到索引表中。他们中一般都有对应字段table_name ,trigger_name等等。

4.我们已经可以自己创建和查询约束,那么如果想要删掉无用的约束呢?

//删除主键

alter table dept drop primary key;

或者

alter table userinfo drop constraint pk_user;

//删除check约束

alter table userinfo drop constraint  ck_age;

//删除外键约束

alter table userinfo drop constraint fk_dept;

用alter table语句:(仅供参考)

 完整用法

ALTER [IGnorE] TABLE tbl_name alter_specification [,alter_specification] ... alter_specification: table_option ...

 | ADD [COLUMN]column_deFinition [FirsT

 | AFTER col_name ]

 | ADD [COLUMN](column_deFinition,...)

| ADD {INDEX|KEY} [index_name] [index_type](index_col_name,...)

 | ADD [CONSTRAINT[symbol]] PRIMARY KEY [index_type] (index_col_name,...)

 | ADD [CONSTRAINT[symbol]] UNIQUE [INDEX|KEY] [index_name] [index_type] (index_col_name,...)

| ADD [FULLTEXT|SPATIAL] [INDEX|KEY] [index_name] (index_col_name,...)

 | ADD [CONSTRAINT[symbol]] FOREIGN KEY [index_name] (index_col_name,...) [reference_deFinition]

 | ALTER [COLUMN]col_name {SET DEFAULT literal | DROP DEFAULT}

| CHANGE [COLUMN] old_col_name column_deFinition [FirsT|AFTERcol_name]

 | MODIFY [COLUMN]column_deFinition [FirsT | AFTER col_name]

| DROP [COLUMN] col_name

 | DROP PRIMARY KEY

| DROP {INDEX|KEY} index_name

 | DROP FOREIGN KEYfk_symbol

| disABLE KEYS | ENABLE KEYS | RENAME [TO] new_tbl_name

| ORDER BY col_name [, col_name] ...

 | CONVERT TO CHaraCTERSET charset_name [COLLATE collation_name]

 | [DEFAULT] CHaraCTERSET charset_name [COLLATE collation_name]

 | disCARD TABLESPACE

 | IMPORT TABLESPACE

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程之家行业资讯频道,感谢您对编程之家的支持

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐