> 데이터 베이스 > MySQL 튜토리얼 > 존재하지 않는 경우에만 MySQL 열을 추가하는 방법은 무엇입니까?

존재하지 않는 경우에만 MySQL 열을 추가하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-15 06:42:11
원래의
229명이 탐색했습니다.

How to Add a MySQL Column Only if It Doesn't Exist?

MySQL 테이블이 없는 경우 열 추가

MySQL에서는 다음과 같은 경우에만 테이블에 열을 동적으로 추가할 수 있습니다. 이미 존재하지 않습니다. 이를 안전하게 달성하기 위한 여러 접근 방식이 있습니다.

저장 프로시저 방법:

DELIMITER $$

DROP PROCEDURE IF EXISTS add_column_if_not_exists $$
CREATE PROCEDURE add_column_if_not_exists()
BEGIN
  IF NOT EXISTS (
    SELECT *
    FROM information_schema.COLUMNS
    WHERE COLUMN_NAME = 'new_column' AND TABLE_NAME = 'my_table'
  ) THEN
    ALTER TABLE my_table ADD COLUMN new_column <column_definition>;
  END IF;
END $$

CALL add_column_if_not_exists() $$

DELIMITER ;
로그인 후 복사

이 저장 프로시저는 IF를 사용하여 열이 이미 존재하는지 확인하고 그렇지 않은 경우 열입니다.

조건부 ALTER TABLE 문(MySQL 8 ):

ALTER TABLE my_table ADD COLUMN IF NOT EXISTS new_column <column_definition>;
로그인 후 복사

이 문은 MySQL 8 이상에서 지원되며 열이 없는 경우 저장 프로시저 없이 열을 추가할 수 있습니다.

예:

예를 생각해 보세요. 테이블:

CREATE TABLE IF NOT EXISTS `my_table` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(255) NOT NULL
);
로그인 후 복사

age 열이 없는 경우 추가하려면 다음을 사용하세요.

DELIMITER $$

DROP PROCEDURE IF EXISTS add_age_column $$
CREATE PROCEDURE add_age_column()
BEGIN
  IF NOT EXISTS (
    SELECT *
    FROM information_schema.COLUMNS
    WHERE COLUMN_NAME = 'age' AND TABLE_NAME = 'my_table'
  ) THEN
    ALTER TABLE my_table ADD COLUMN age INT NOT NULL DEFAULT 0;
  END IF;
END $$

CALL add_age_column() $$

DELIMITER ;
로그인 후 복사

위 내용은 존재하지 않는 경우에만 MySQL 열을 추가하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿