> 데이터 베이스 > MySQL 튜토리얼 > DROP 데이터베이스 권한 없이 MySQL 데이터베이스의 모든 테이블을 삭제하는 방법은 무엇입니까?

DROP 데이터베이스 권한 없이 MySQL 데이터베이스의 모든 테이블을 삭제하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-10-31 19:42:02
원래의
774명이 탐색했습니다.

How to Drop All Tables in a MySQL Database Without DROP Database Permissions?

명령줄을 통해 DROP 데이터베이스 권한 없이 MySQL 테이블 삭제

쿼리에서 언급했듯이 사용자에게는 데이터베이스를 다시 생성할 수 있는 권한이 부족할 수 있지만 테이블 삭제를 실행할 수 있습니다. 이 문제를 해결하기 위해 명령줄에서 직접 DROP 데이터베이스 권한 없이 모든 MySQL 테이블을 제거하는 솔루션을 제시합니다.

해결책:

특정 테이블 내의 모든 테이블을 삭제하려면 데이터베이스의 경우 다음 명령 시퀀스를 실행할 수 있습니다.

  1. 외래 키 검사 비활성화:

    SET FOREIGN_KEY_CHECKS = 0; 
    로그인 후 복사
  2. 테이블 이름을 단일 문자열로 연결합니다.

    SET @tables = NULL;
    SELECT GROUP_CONCAT('`', table_schema, '`.`', table_name, '`') INTO @tables
      FROM information_schema.tables 
      WHERE table_schema = 'database_name'; -- Replace 'database_name' with the actual database name.
    로그인 후 복사
  3. DROP TABLE 문 만들기:

    SET @tables = CONCAT('DROP TABLE ', @tables);
    로그인 후 복사
  4. 결합된 DROP 문 준비 및 실행:

    PREPARE stmt FROM @tables;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
    로그인 후 복사
  5. 외래 키 검사 다시 활성화:

    SET FOREIGN_KEY_CHECKS = 1; 
    로그인 후 복사

이 접근 방식을 사용하면 모든 테이블이 올바른 순서로 삭제되어 외래 키 제약 조건 위반을 방지할 수 있습니다. .

위 내용은 DROP 데이터베이스 권한 없이 MySQL 데이터베이스의 모든 테이블을 삭제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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