>  기사  >  데이터 베이스  >  MySQL의 제약 조건에 대한 자세한 설명

MySQL의 제약 조건에 대한 자세한 설명

PHPz
PHPz원래의
2024-02-22 14:24:04648검색

MySQL의 제약 조건에 대한 자세한 설명

MySQL의 제약 조건에 대한 자세한 설명

MySQL 데이터베이스에서 제약 조건은 테이블 열의 값 범위와 데이터 무결성을 정의하고 제한하는 데 사용되는 규칙입니다. 테이블 생성 중에 열에 제약 조건을 추가하면 데이터 정확성과 일관성을 보장할 수 있습니다. 이 기사에서는 MySQL에서 일반적으로 사용되는 제약 조건 유형을 소개하고 구체적인 코드 예제를 제공합니다.

  1. PRIMARY KEY(기본 키 제약 조건)
    기본 키는 테이블의 열 또는 열 그룹에 대한 고유 식별자입니다. 이는 테이블의 각 행의 고유성을 보장합니다. PRIMARY KEY 제약 조건을 사용하면 테이블에 기본 키가 하나만 있고 값이 중복되지 않도록 할 수 있습니다.
    다음은 테이블에 기본 키 제약 조건을 추가하는 방법을 보여주는 예입니다.
CREATE TABLE students (
    id INT PRIMARY KEY,
    name VARCHAR(50),
    age INT
);
  1. FOREIGN KEY(외래 키 제약 조건)
    외래 키는 여러 테이블 간의 관계를 설정하는 데 사용됩니다. 데이터 무결성을 보장하기 위해 다른 테이블의 기본 키를 참조하는 열 또는 열 집합입니다. FOREIGN KEY 제약 조건이 외래 키 열에 정의되면 MySQL은 삽입되거나 업데이트된 값이 관련 테이블에 있는지 자동으로 확인합니다.
    다음은 테이블에 외래 키 제약 조건을 추가하는 방법을 보여주는 예입니다.
CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    product_id INT,
    customer_id INT,
    FOREIGN KEY (product_id) REFERENCES products(product_id),
    FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
);
  1. UNIQUE(고유 제약 조건)
    고유 제약 조건은 테이블의 열이 고유 값만 허용하도록 보장합니다. 경우에 따라 중복 값을 피하기 위해 열에 UNIQUE 제약 조건을 추가할 수도 있습니다.
    다음은 테이블에 고유 제약 조건을 추가하는 방법을 보여주는 예입니다.
CREATE TABLE employees (
    employee_id INT PRIMARY KEY,
    email VARCHAR(50) UNIQUE,
    department_id INT
);
  1. CHECK(검사 제약 조건)
    CHECK 제약 조건은 테이블의 열 값 범위를 사용자 지정하는 데 사용됩니다. CHECK 제약 조건을 사용하면 특정 조건을 충족하는 데이터만 테이블에 삽입되도록 할 수 있습니다.
    다음은 CHECK 제약 조건을 사용하는 방법을 보여주는 예입니다.
CREATE TABLE products (
    product_id INT PRIMARY KEY,
    product_name VARCHAR(50),
    quantity INT,
    price DECIMAL(10, 2),
    CONSTRAINT CHK_quantity CHECK (quantity >= 0),
    CONSTRAINT CHK_price CHECK (price > 0)
);
  1. DEFAULT(기본 제약 조건)
    DEFAULT 제약 조건은 새 행이 삽입될 때 값이 제공되지 않는 경우 열의 기본값을 설정하는 데 사용됩니다. 명시적으로는 자동으로 기본값이 사용됩니다.
    다음은 테이블에 기본 제약 조건을 추가하는 방법을 보여주는 예입니다.
CREATE TABLE users (
    user_id INT PRIMARY KEY,
    username VARCHAR(50),
    password VARCHAR(50) DEFAULT '123456',
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

위는 MySQL에서 일반적으로 사용되는 제약 조건 유형과 사용 방법을 소개합니다. 제약 조건을 사용하면 데이터베이스의 데이터 무결성과 일관성이 보장됩니다. 제약 조건을 적절하게 사용하면 오류와 불일치하는 데이터를 줄일 수 있으며 데이터베이스의 효율성과 안정성을 향상시킬 수 있습니다. 이 글이 MySQL의 제약 기능을 이해하고 사용하는 데 도움이 되기를 바랍니다.

위 내용은 MySQL의 제약 조건에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.