d constraint pk_emp_pk_03 primary key(EMPLOYEE_ID)
--方法四(联合主键) 在表级定义
--账号表
create table account_01
(
accounid varchar2(18) primary key, --账号
balance number(10,2) --余额
)
--存款信息表
create table inaccount_01
(
accounid varchar2(18), --账号
inbalance number(10,2), --存入金额
indate timestamp, --存款时间
constraint pk_inaccount_01 primary key(accounid,indate)
)
insert into inaccount_01(accounid,inbalance,indate) values('1111',12,sysdate);
insert into inaccount(accounid,inbalance,indate) values('1111',10,sysdate);
www.2cto.com
--方法五 ,在外部定义
create table account_02
(
accounid varchar2(18) primary key, --账号
balance number(10,2) --余额
)
--存款信息表
create table inaccount_02
(
accounid varchar2(18), --账号
inbalance number(10,2), --存入金额
indate timestamp --存款时间
)
alter table inaccount_02
add constraint pk_inaccount_02 primary key(accounid,indate)
--**********************************************************************************
--外键约束( FOREIGN KEY)
* 外键是构建于一个表的两个字段或者两个表的两个字段之间的关系
* 外键确保了相关的两个字段的关系:
* 子表外键列的值必须在主表参照列值的范围内,或者为空
* 主表主键值被子表参照时,主表记录不允许被删除
* 外键约束条件参照的是主表的一个或者多个字段的值,通常被外键参照的 是
主表的主键或者唯一键
--在表级定义外键约束语法格式
constraint 约束的名称 foreign key(外键字段) references 表(主键)
* 约束的名称 自定义
* 约束的类型(foreign key)
* references 表(主键) 参照表的字段 一般为主表的主键
www.2cto.com
--方法一 在表级定义
create table deptfk_01
(
DEPARTMENT_ID NUMBER(4) primary key,
DEPARTMENT_NAME VARCHAR2(30),
MANAGER_ID NUMBER(6),
LOCATION_ID NUMBER(4)
)
create table EMPFK_01
(
EMPLOYEE_ID NUMBER(6) ,
FIRST_NAME VARCHAR2(20),
DEPARTMENT_ID NUMBER(4),
constraint fk_EMPFK_01 foreign key(DEPARTMENT_ID) references deptfk_01
(DEPARTMENT_ID)
)
www.2cto.com
--方法二 在表的外部定义
--在外部定义外键约束的语法格式
alter table table_name
add constraint 约束的名称 foreign key(外键字段) references 表(主键)
* 约束的名称 自定义
* 约束的类型(foreign key)
* references 表(主键) 参照表的字段 一般为主表的主键
create table deptfk_02
(
DEPARTMENT_ID NUMBER(4) primary key,
DEPARTMENT_NAME VARCHAR2(30),
MANAGER_ID NUMBER(6),
LOCATION_ID NUMBER(4)
)
create table EMPFK_02
(
EMPLOYEE_ID NUMBER(6) ,
FIRST_NAME VARCHAR2(20),
DEPARTMENT_ID NUMBER(4)
)
alter table EMPFK_02
add constraint fk_EMPFK_02 foreign key(DEPARTMENT_ID) references deptfk_02
(DEPARTMENT_ID)
--方法三(主外键作用于一个表的两个字段)
create table emp_two
(
EMPLOYEE_ID NUMBER(6) primary key,
FIRST_NAME VARCHAR2(20),
MANAGER_ID NUMBER(6) --外键
)
www.2cto.com
alter table emp_two
add constraint fk_emp_two foreign key(MANAGER_ID) references emp_two
(EMPLOYEE_ID)
--************************************************************************************
--check约束
* Check约束条件是一种比较特殊的约束条件,通过check定义,
* 强制定义在字段上的每一记录都要满足check中定义的条件。
* 在check中定义检查的条件表达式,进入表中的数据必须符合check中设置的条件
create table empck
(
EMPLOYEE_ID NUMBER(6) primary key,
FIRST