0

假设一个具有大量表(200+)的数据库,我该如何执行代表数据库中所有表的SELECT * FROM <> LIMIT 3;位置?<>我的目标是了解每个表包含的内容,其中显示的列名DESCRIBE并不是特别有用。因此,我想从每个表中查看 3 条记录。

我知道我可以通过迭代输出轻松地在 PHP 中编写脚本,show tables;但是我正在寻找在 MySQL 解释器(mysql>提示符)上运行的命令。

4

1 回答 1

1

它在此链接下详细描述(虽然我自己没有尝试过,它只是在我的书签中):

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;');
于 2013-02-22T12:03:13.607 回答