oracle添加各种约束条件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle添加各种约束条件相关的知识,希望对你有一定的参考价值。

--非空约束
ALTER TABLE studen MODIFY (studentname NOT NULL);
--唯一约束(身份证号)
ALTER TABLE student ADD CONSTRAINT UK_student_identityCard UNIQUE (identitycard); --默认约束(地址) ALTER TABLE student modify address DEFAULT ‘地址不详‘; --检查约束(出生日期在1980年1月1日之后) ALTER TABLE student ADD CONSTRAINT CK_student_borndate CHECK (borndate > TO_date(‘1980-01-01‘,‘yyyy-MM-dd‘) ); --外键约束(主表grade和从表student建立引用关系) ALTER TABLE student ADD CONSTRAINT FK_student_grade_GradeId FOREIGN KEY (gradeid) REFERENCES Grade (gradeid); --默认约束(examdate考试日期默认当前时间) ALTER TABLE RESULT modify examdate DEFAULT SYSDATE; --增加复合主键 ALTER TABLE result ADD CONSTRAINT PK_result primary key (studentno, subjectno,examdate); --删除约束
ALTER TABLE pet DROP CONSTRAINT UK_student_identityCard;
--学生表 CREATE TABLE student(
studentno NUMBER(11) NOT NULL PRIMARY KEY,
loginpwd NVARCHAR2(20) NOT NULL,
studentname NVARCHAR2(20),
gradeid NUMBER(11) NOT NULL,
sex NCHAR(2) NOT NULL,
phone NVARCHAR2(50) NOT NULL,
borndate DATE NOT NULL,
address NVARCHAR2(255) NOT NULL,
email NVARCHAR2(50) NOT NULL,
identitycard NVARCHAR2(18) NOT NULL );
--年级表 CREATE TABLE grade(
gradeid NUMBER(11) NOT NULL PRIMARY KEY,
gradename NVARCHAR2(20) NOT NULL );

--课程表 CREATE TABLE subject(
subjectno NUMBER(11) NOT NULL PRIMARY KEY,
subjectname NVARCHAR2(50) NOT NULL,
classhour NUMBER(4) NOT NULL,
gradeid NUMBER(11) NOT NULL );

--成绩表 CREATE TABLE RESULT(
studentno NUMBER(11) NOT NULL,
subjectno NUMBER(11) NOT NULL,
examdate DATE NOT NULL,
studentresult NUMBER(4) NOT NULL );
约束命名规范   
 非空约束     NN_表名_列名 
 唯一约束     UK_表名_列名
 主键约束     PK_表名
 外键约束     FK_表名_列名
 条件约束     CK_表名_列名
 默认约束     DF_表名_列名

  

 




































以上是关于oracle添加各种约束条件的主要内容,如果未能解决你的问题,请参考以下文章

oracle数据库添加,查询,删除检查约束

oracle04 约束,索引

Oracle笔记之约束

day05_oracle各种约束示例

oracle数据导入时,提示违反唯一约束性?

如何在导入过程中禁用Oracle约束条件和触发器