sql >> Databasteknik >  >> RDS >> Mysql

Hur tar man bort alla MySQL-tabeller från kommandoraden utan DROP-databasbehörigheter?

Du kan generera uttalande så här:DROP TABLE t1, t2, t3, ... och använd sedan förberedda satser för att köra det:

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

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


  1. Tillåter oracle alternativet för oengagerad läsning?

  2. SQL-kolumnnamn samma som PL/SQL-variabelnamn - Hur kan detta göras i en select-sats?

  3. Topp 10 bästa praxis i MySQL

  4. Hur konverterar man kommaseparerade värden till rader i Oracle?