>데이터 베이스 >MySQL 튜토리얼 >MySQL 테이블을 생성하는 방법

MySQL 테이블을 생성하는 방법

PHPz
PHPz원래의
2023-04-21 11:20:2115360검색

MySQL은 많은 애플리케이션의 데이터 저장 및 처리를 위한 기본 선택으로 널리 사용되는 관계형 데이터베이스 관리 시스템입니다. MySQL을 사용할 때 테이블 생성은 반드시 숙지해야 할 매우 중요한 기술입니다. 이번 포스팅에서는 MySQL에서 테이블을 생성하는 방법을 소개하겠습니다.

  1. 전제 조건
    MySQL 테이블을 생성하기 전에 MySQL 서버를 설치 및 구성하고 MySQL 클라이언트 도구(예: 명령줄 또는 MySQL Workbench) 사용에 익숙해져야 합니다. 또한 테이블을 생성하려면 충분한 권한이 필요합니다. 작업이 로컬에서 수행되는 경우 루트 사용자로 로그인할 수 있으며, 원격 서버에서 작업이 수행되는 경우 해당 권한이 필요합니다.
  2. 데이터베이스 선택
    테이블을 생성하기 전에 테이블을 생성하려는 대상 데이터베이스를 선택해야 합니다. 데이터베이스가 이미 존재하는 경우 다음 명령을 사용하여 해당 데이터베이스로 전환할 수 있습니다.
use database_name;

여기서 데이터베이스_이름은 대상 데이터베이스의 이름입니다.

대상 데이터베이스가 아직 존재하지 않으면 데이터베이스를 생성하고 다음 명령을 사용하여 이를 현재 데이터베이스로 설정해야 합니다:

CREATE DATABASE database_name;
USE database_name;
  1. Create table
    CREATE TABLE 문을 사용하여 새 MySQL 테이블을 생성할 수 있습니다. 일반적으로 CREATE TABLE 문에는 다음 구성 요소가 포함됩니다.
  • 테이블 이름: 새 테이블의 이름입니다.
  • 열 이름 및 데이터 유형: 생성할 테이블의 각 열과 각 열의 데이터 유형입니다.
  • 기본 키: 모든 테이블에는 각 데이터 행을 고유하게 식별하는 기본 키가 있어야 합니다.
  • 제약조건: 특정 열에 대한 제한 및 요구 사항을 정의하는 데 사용됩니다.
  • 기타 옵션: 파티셔닝 및 인덱싱 등.

다음은 기본 MySQL 테이블 생성 문의 예입니다.

CREATE TABLE table_name (
    column_1 datatype constraint,
    column_2 datatype constraint,
    PRIMARY KEY (column_1)
);

여기서 table_name은 새 테이블의 이름이고, column_1과 column_2는 생성할 열 이름이고, datatype은 열의 데이터 유형이며, 제약 조건은 열의 제한 사항 또는 요구 사항입니다. PRIMARY KEY는 각 데이터 행을 고유하게 식별하는 열인 테이블의 기본 키를 지정하는 데 사용됩니다.

예를 들어, 다음은 Students라는 MySQL 테이블에 대한 create 문의 예입니다.

CREATE TABLE students (
    id INT UNSIGNED NOT NULL AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    age INT,
    gender ENUM('male','female') NOT NULL,
    PRIMARY KEY (id)
);

이 예에서 Students는 테이블의 이름이고, id는 자동 증가 정수 열이며 기본 키로 지정됩니다. name은 255자의 텍스트 열이고, age는 정수 열이며, 성별은 '남성', '여성' 두 값만 포함할 수 있는 열거형 열입니다.

  1. 열 제약 조건 추가
    열을 생성할 때 다음을 포함하여 다양한 제약 조건을 사용하여 열 값을 제한하거나 요구할 수 있습니다.
  • NOT NULL: 열은 null일 수 없습니다.
  • UNIQUE: 열의 모든 값은 고유해야 합니다.
  • DEFAULT: 열의 기본값을 설정합니다.
  • CHECK: 특정 조건에서 값의 범위를 제한하는 등 특정 제한 사항을 지정합니다.
  • PRIMARY KEY: 이 열을 테이블의 기본 키로 지정합니다.
  • FOREIGN KEY: 이 열이 다른 테이블의 외래 키와 연결되도록 지정합니다.

다음은 이러한 제약 조건을 사용하는 방법을 보여주는 몇 가지 예입니다.

  • NULL 값 및 고유성 금지:
CREATE TABLE employees (
    id INT UNSIGNED NOT NULL AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    email VARCHAR(255) NOT NULL UNIQUE,
    age INT NOT NULL,
    PRIMARY KEY (id)
);

이 예에서는 이메일 열이 고유해야 하므로 UNIQUE 제약 조건이 사용됩니다.

  • 기본값 추가:
CREATE TABLE customers (
    id INT UNSIGNED NOT NULL AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    address TEXT,
    created_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    PRIMARY KEY (id)
);

이 예에서 Created_date 열에는 현재 타임스탬프로 설정된 기본값이 있으므로 새 레코드가 생성될 때마다 이 열의 값을 수동으로 지정할 필요가 없습니다.

  • 값 범위 확인:
CREATE TABLE orders (
    id INT UNSIGNED NOT NULL AUTO_INCREMENT,
    product_name VARCHAR(255) NOT NULL,
    quantity INT NOT NULL,
    price DECIMAL(10,2) NOT NULL,
    status ENUM('pending','processing','shipped') DEFAULT 'pending',
    CONSTRAINT ck_price CHECK (price > 0),
    PRIMARY KEY (id)
);

이 예에서 가격 열은 CHECK 제약 조건을 통해 값 범위를 제한하므로 열 값이 0보다 커야 합니다. 상태 열의 기본값은 '보류 중'이므로 새 레코드를 생성할 때 이 열의 값을 수동으로 지정할 필요가 없습니다.

  • 외래 키 추가:
CREATE TABLE orders (
    id INT UNSIGNED NOT NULL AUTO_INCREMENT,
    customer_id INT UNSIGNED NOT NULL,
    product_name VARCHAR(255) NOT NULL,
    quantity INT NOT NULL,
    price DECIMAL(10,2) NOT NULL,
    PRIMARY KEY (id),
    FOREIGN KEY (customer_id) REFERENCES customers(id)
);

이 예에서 customer_id 열은 고객 테이블의 id 열과 연결되어 있으므로 FOREIGN KEY 제약 조건을 사용하여 외래 키를 생성합니다. 이는 customer_id 열의 값이 고객 테이블의 id 열 값과 일치해야 함을 의미합니다.

  1. 요약
    MySQL에서 테이블을 생성하는 것은 필수 기술입니다. 이 글에서는 CREATE TABLE 문과 다양한 열 제약 조건을 사용하여 MySQL 테이블을 생성하는 방법을 소개합니다. 그 밖에도 많은 선택사항과 제약사항이 있으므로 실제로는 지속적인 학습과 탐구가 필요합니다.

위 내용은 MySQL 테이블을 생성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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