Oracle(14)什么是唯一键(Unique Key)?

418 阅读3分钟

唯一键(Unique Key)是数据库表中的一个或多个列,它们的值必须在整个表中唯一,但允许包含NULL值。唯一键的主要目的是确保表中每一行的数据在指定的列(或列组合)中是唯一的,以防止重复数据的出现。

特点

  1. 唯一性(Uniqueness):唯一键列的值在整个表中必须是唯一的。
  2. 允许NULL值:与主键不同,唯一键列允许包含一个或多个NULL值(但每个NULL值视为不同的值)。
  3. 单列或组合列:唯一键可以是单个列,也可以是由多个列组成的组合键(Composite Key)。

创建唯一键的SQL语法

  1. 在表创建时添加唯一键

    CREATE TABLE employees (
        employee_id NUMBER PRIMARY KEY,
        email VARCHAR2(100) UNIQUE,
        phone_number VARCHAR2(20)
    );
    
  2. 在表创建后添加唯一键

    ALTER TABLE employees ADD CONSTRAINT unique_email UNIQUE (email);
    
  3. 设置唯一键时使用约束名

    CREATE TABLE employees (
        employee_id NUMBER PRIMARY KEY,
        email VARCHAR2(100),
        phone_number VARCHAR2(20),
        CONSTRAINT unique_email UNIQUE (email)
    );
    

唯一键示例

示例1:使用单列唯一键

CREATE TABLE users (
    user_id NUMBER PRIMARY KEY,
    username VARCHAR2(50) NOT NULL,
    email VARCHAR2(100) UNIQUE,
    password VARCHAR2(50) NOT NULL
);

在这个示例中,email列被定义为唯一键,确保每个用户的电子邮件地址在表中是唯一的。

示例2:使用组合唯一键

CREATE TABLE orders (
    order_id NUMBER PRIMARY KEY,
    customer_id NUMBER,
    product_id NUMBER,
    order_date DATE,
    CONSTRAINT unique_order UNIQUE (customer_id, product_id)
);

在这个示例中,customer_idproduct_id的组合被定义为唯一键,确保每个客户在同一个产品上不会有重复的订单。

示例3:在表创建后添加唯一键

CREATE TABLE products (
    product_id NUMBER PRIMARY KEY,
    product_name VARCHAR2(100),
    product_code VARCHAR2(50)
);

ALTER TABLE products ADD CONSTRAINT unique_product_code UNIQUE (product_code);

在这个示例中,表创建后使用ALTER TABLE语句添加了唯一键约束。

唯一键与主键的区别

  1. 唯一性:主键和唯一键都确保列中的值是唯一的。
  2. NULL值:主键列不能为空,而唯一键列可以包含NULL值。
  3. 数量:每个表只能有一个主键,但可以有多个唯一键。
  4. 主键是唯一键的超集:主键是一个特殊的唯一键,除了唯一性之外,还必须是非空的。

注意事项

  • 数据一致性:唯一键约束确保列中的数据不重复,有助于维护数据完整性。
  • 性能影响:唯一键约束需要数据库在插入或更新时检查唯一性,因此可能会对性能产生一些影响。
  • 组合键:在定义组合唯一键时,需要确保组合列的值在表中是唯一的。

通过使用唯一键,可以确保数据库表中的特定列或列组的值是唯一的,从而防止数据重复和提高数据完整性。