为什么MySQL Workbench会为视图生成占位符表?

aut*_*tix 5 mysql database view mysql-workbench

在我在MySQL Workbench中创建的数据库模型中,我定义了一个视图.当我现在从diagramm(Menu -> Database -> Forward EngineerCtrl + G)生成SQL时,会为我的视图创建此代码:

-- -----------------------------------------------------
-- Placeholder table for view `myview`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `myview` (...table columns...);
SHOW WARNINGS;

-- -----------------------------------------------------
-- View `myview`
-- -----------------------------------------------------
DROP VIEW IF EXISTS `myview` ;
SHOW WARNINGS;
DROP TABLE IF EXISTS `myview`;
SHOW WARNINGS;
DELIMITER $$
CREATE OR REPLACE VIEW `myview` AS

...view definition...

$$
DELIMITER ;

;
SHOW WARNINGS;


SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
Run Code Online (Sandbox Code Playgroud)

为什么要创建此占位符表?

谢谢

Mik*_*hke 5

占位符是创建的(不仅由 WB 而且也由例如 mysqldump)来解决循环引用。视图定义可以引用需要该视图的表(或需要表的表,该表需要最终需要初始视图的视图)。这无法自动检测或解决,除非通过定义虚拟视图(临时为表,因为视图在大多数方面类似于表)然后在所有其他对象可用时重新定义它们。