not+null+非空 unique+唯一约束 primary+key+主键约束 foreign+key+外键约束 check+检查约束+对填写内容约束default+默认值约束 创建表+(添加)
时间: 2023-12-14 14:33:58 浏览: 78
以下是Oracle数据库中常见约束的介绍和创建表时添加约束的示例:
- not null约束:用于确保列中的值不为空。在创建表时,可以在列定义中使用NOT NULL关键字来定义非空约束。例如:
```sql
CREATE TABLE employees (
employee_id NUMBER(5) PRIMARY KEY,
first_name VARCHAR2(50) NOT NULL,
last_name VARCHAR2(50) NOT NULL,
email VARCHAR2(100) NOT NULL UNIQUE,
hire_date DATE NOT NULL,
salary NUMBER(8,2) NOT NULL
);
```
- unique约束:用于确保列中的值是唯一的。在创建表时,可以在列定义中使用UNIQUE关键字来定义唯一约束。例如:
```sql
CREATE TABLE departments (
department_id NUMBER(5) PRIMARY KEY,
department_name VARCHAR2(50) NOT NULL UNIQUE,
manager_id NUMBER(5),
location_id NUMBER(5)
);
```
- primary key约束:用于定义表中的主键。在创建表时,可以在列定义中使用PRIMARY KEY关键字来定义主键约束。例如:
```sql
CREATE TABLE countries (
country_id CHAR(2) PRIMARY KEY,
country_name VARCHAR2(40) NOT NULL,
region_id NUMBER(1)
);
```
- foreign key约束:用于确保表中的数据完整性,通过与另一个表的主键或唯一键进行关联。在创建表时,可以使用FOREIGN KEY关键字来定义外键约束。例如:
```sql
CREATE TABLE employees (
employee_id NUMBER(5) PRIMARY KEY,
first_name VARCHAR2(50) NOT NULL,
last_name VARCHAR2(50) NOT NULL,
email VARCHAR2(100) NOT NULL UNIQUE,
hire_date DATE NOT NULL,
salary NUMBER(8,2) NOT NULL,
department_id NUMBER(5),
CONSTRAINT fk_department_id FOREIGN KEY (department_id) REFERENCES departments (department_id)
);
```
- check约束:用于确保列中的值符合指定的条件。在创建表时,可以在列定义中使用CHECK关键字来定义检查约束。例如:
```sql
CREATE TABLE employees (
employee_id NUMBER(5) PRIMARY KEY,
first_name VARCHAR2(50) NOT NULL,
last_name VARCHAR2(50) NOT NULL,
email VARCHAR2(100) NOT NULL UNIQUE,
hire_date DATE NOT NULL,
salary NUMBER(8,2) NOT NULL,
commission_pct NUMBER(2,) CHECK (commission_pct >= 0 AND commission_pct <= 1)
);
```
- default约束:用于在插入数据时为列提供默认值。在创建表时,可以在列定义中使用DEFAULT关键字来定义默认值约束。例如:
```sql
CREATE TABLE employees (
employee_id NUMBER(5) PRIMARY KEY,
first_name VARCHAR2(50) NOT NULL,
last_name VARCHAR2(50) NOT NULL,
email VARCHAR2(100) NOT NULL UNIQUE,
hire_date DATE NOT NULL,
salary NUMBER(8,2) NOT NULL,
commission_pct NUMBER(2,2) DEFAULT 0
);
```
- 创建表时添加约束:在创建表时,可以在列定义之后使用CONSTRAINT关键字来添加约束。例如:
```sql
CREATE TABLE employees (
employee_id NUMBER(5) PRIMARY KEY,
first_name VARCHAR2(50) NOT NULL,
last_name VARCHAR2(50) NOT NULL,
email VARCHAR2(100) NOT NULL UNIQUE,
hire_date DATE NOT NULL,
salary NUMBER(8,2) NOT NULL,
department_id NUMBER(5),
CONSTRAINT fk_department_id FOREIGN KEY (department_id) REFERENCES departments (department_id),
CONSTRAINT chk_salary CHECK (salary >= 0)
);
```
阅读全文