Oracle中的约束(Constraint)是用来确保数据完整性的一种方法。约束可以在表创建时定义,也可以在表创建后添加。约束有以下几种类型:
- 主键约束(Primary Key Constraint):确保列中的值唯一且不为空。
- 外键约束(Foreign Key Constraint):确保一个表中的列引用另一个表中的主键或唯一列。
- 唯一约束(Unique Constraint):确保列中的值唯一。
- 检查约束(Check Constraint):确保列中的值满足特定条件。
- 非空约束(Not Null Constraint):确保列中的值不为空。
以下是一些示例,说明如何使用约束来确保数据完整性:
- 创建带有主键约束的表:
CREATE TABLE employees ( emp_id NUMBER PRIMARY KEY, first_name VARCHAR2(50), last_name VARCHAR2(50) );
- 创建带有外键约束的表:
CREATE TABLE departments ( dept_id NUMBER PRIMARY KEY, dept_name VARCHAR2(50) ); CREATE TABLE employees ( emp_id NUMBER PRIMARY KEY, first_name VARCHAR2(50), last_name VARCHAR2(50), dept_id NUMBER, FOREIGN KEY (dept_id) REFERENCES departments(dept_id) );
- 创建带有唯一约束的表:
CREATE TABLE employees ( emp_id NUMBER PRIMARY KEY, first_name VARCHAR2(50), last_name VARCHAR2(50), email VARCHAR2(100) UNIQUE );
- 创建带有检查约束的表:
CREATE TABLE employees ( emp_id NUMBER PRIMARY KEY, first_name VARCHAR2(50), last_name VARCHAR2(50), age NUMBER CHECK (age >= 18 AND age <= 65) );
- 创建带有非空约束的表:
CREATE TABLE employees ( emp_id NUMBER PRIMARY KEY, first_name VARCHAR2(50) NOT NULL, last_name VARCHAR2(50) NOT NULL );
通过使用这些约束,您可以确保Oracle数据库中的数据保持完整性。