假设一个具有大量表(200+)的数据库,我该如何执行代表数据库中所有表的SELECT * FROM <> LIMIT 3;
位置?<>
我的目标是了解每个表包含的内容,其中显示的列名DESCRIBE
并不是特别有用。因此,我想从每个表中查看 3 条记录。
我知道我可以通过迭代输出轻松地在 PHP 中编写脚本,show tables;
但是我正在寻找在 MySQL 解释器(mysql>
提示符)上运行的命令。
假设一个具有大量表(200+)的数据库,我该如何执行代表数据库中所有表的SELECT * FROM <> LIMIT 3;
位置?<>
我的目标是了解每个表包含的内容,其中显示的列名DESCRIBE
并不是特别有用。因此,我想从每个表中查看 3 条记录。
我知道我可以通过迭代输出轻松地在 PHP 中编写脚本,show tables;
但是我正在寻找在 MySQL 解释器(mysql>
提示符)上运行的命令。
它在此链接下详细描述(虽然我自己没有尝试过,它只是在我的书签中):
http://www.youdidwhatwithtsql.com/mysql-clone-of-sp_msforeachtable/624
DELIMITER $$
DROP PROCEDURE IF EXISTS `usp_mysql_foreachtable`$$
CREATE PROCEDURE `usp_mysql_foreachtable`(IN sql_string VARCHAR(1000))
LANGUAGE SQL
NOT DETERMINISTIC
COMMENT 'Functional clone of sp_MsForEachTable'
BEGIN
DECLARE var_tablename VARCHAR(100);
DECLARE last_row BIT;
DECLARE table_cursor CURSOR FOR SELECT TABLE_NAME
FROM information_schema.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
AND TABLE_SCHEMA = DATABASE();
DECLARE CONTINUE HANDLER FOR NOT FOUND SET last_row = 1;
OPEN table_cursor;
FETCH table_cursor INTO var_tablename;
SET last_row = 0;
SET @var = '';
lbl_table_cursor: LOOP
SET @qry = REPLACE(sql_string, '?', var_tablename);
PREPARE q FROM @qry;
EXECUTE q;
DEALLOCATE PREPARE q;
FETCH table_cursor INTO var_tablename;
IF last_row = 1 THEN
LEAVE lbl_table_cursor;
END IF;
END LOOP lbl_table_cursor;
CLOSE table_cursor;
END$$
DELIMITER ;
然后你用
CALL usp_mysql_foreachtable('SELECT * FROM ? LIMIT 3;');