请举例说明primary key,default,not null,unique key,foreign key这几种约束的应用场景,并说明主键约束和唯一性约束的区别
时间: 2024-04-02 07:37:51 浏览: 73
好的,我来解答这个问题。
- Primary key(主键约束):主键约束是一种用于标识表中唯一记录的约束,每个表只能有一个主键。主键可以是一个或多个列的组合。应用场景:在一个表中,某个字段是唯一的标识符,例如用户表中的用户ID,可以将该字段设为主键。
- Default(默认值约束):默认值约束是一种在插入数据时,如果没有为某个字段赋值,则该字段将被赋予的默认值约束。应用场景:例如,在一个订单表中,如果没有指定订单状态,则默认为“未支付”。
- Not null(非空约束):非空约束是一种要求在插入数据时,某个字段必须有值的约束。应用场景:例如,在一个用户表中,用户名和密码都是必填项,这时可以将这两个字段设为非空约束。
- Unique key(唯一性约束):唯一性约束是一种要求某个字段的值在整个表中唯一的约束。唯一性约束可以是一个或多个列的组合。应用场景:例如,在一个商品表中,商品编号必须唯一,可以将该字段设为唯一性约束。
- Foreign key(外键约束):外键约束是一种要求某个字段的值必须在另一个表中存在的约束。应用场景:例如,在一个订单表中,订单中的商品ID必须存在于商品表中,可以将商品ID设为外键约束。
主键约束和唯一性约束的区别在于:
- 主键约束是一种通过标识符来唯一标识表中的记录的约束,每个表只能有一个主键。主键可以是一个或多个列的组合。
- 唯一性约束是一种要求某个字段的值在整个表中唯一的约束。唯一性约束可以是一个或多个列的组合,每个表可以有多个唯一性约束。
相关问题
not+null+非空 unique+唯一约束 primary+key+主键约束 foreign+key+外键约束 check+检查约束+对填写内容约束default+默认值约束 创建表+(添加)
以下是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)
);
```
各字段有哪些约束?如何利用这些约束? 唯一 unique: 缺省 default: 非空 not null: 主键 primary key: 外键 foreign key: 值域检查check:
这些约束可以用来保证数据的完整性和一致性。比如,唯一约束可以防止重复数据的插入,主键约束可以保证每个记录都有唯一的标识符,非空约束可以保证必须有值,外键约束可以保证两张表之间的关系正确等等。我们可以在数据库中设置这些约束,当尝试违反约束时,数据库会自动拒绝操作并给出错误提示。这能够避免一些常见的错误,提高数据的正确性和可靠性。
阅读全文