테스트 사이트 - 개발 중인 베타 버전입니다

Mysql Table 일괄 삭제 방법.

· 10년 전 · 450

작업을 하다보면 테이블 전체를 일괄로 삭제해야할때가 있는데요.

 

물론 테이블이 많지 않으면 하나하나 Drop 을 해주면 되지만 그렇지 않은경우가 종종있습니다.

 

 

 

이럴때 사용하면 좋은 팁입니다.

 

 

 


 

 

SET @tables = NULL;
 SELECT GROUP_CONCAT(table_schema, '.', table_name) INTO @tables
   FROM information_schema.tables 
   WHERE table_schema = 'DB명'; -- specify DB name here.

 SET @tables = CONCAT('DROP TABLE ', @tables);
 PREPARE stmt FROM @tables;
 EXECUTE stmt;
 DEALLOCATE PREPARE stmt;

 

 


 

 

위에 DB명이라는 부분에 삭제할 데이터베이스이름을 넣고 쿼리를 실행하면됩니다.

 

 

그대로 복사해서 실행하면 아래처럼 실행되니 부분부분 궁금하신분은 참고하세요.

 

 

 


 

 

 

mysql> SET @tables = NULL;
Query OK, 0 rows affected (0.00 sec)

 

mysql>  SELECT GROUP_CONCAT(table_schema, '.', table_name) INTO @tables
    ->    FROM information_schema.tables 
    ->    WHERE table_schema = 'DB명'; -- specify DB name here.
Query OK, 1 row affected (0.01 sec)

 

mysql> 
mysql>  SET @tables = CONCAT('DROP TABLE ', @tables);
Query OK, 0 rows affected (0.00 sec)

 

mysql>  PREPARE stmt FROM @tables;
Query OK, 0 rows affected (0.00 sec)


Statement prepared

mysql>  EXECUTE stmt;
Query OK, 0 rows affected (0.01 sec)

 

mysql>  DEALLOCATE PREPARE stmt; 
Query OK, 0 rows affected (0.00 sec)

 

mysql> show tables;
Empty set (0.00 sec)


댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

게시판 목록

팁게시판

디자인과 관련된 유용한 정보를 공유하세요.
질문은 상단의 QA에서 해주시기 바랍니다.
글쓰기