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

时间:2013-03-14 18:33:23

标签: 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;

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

THX

1 个答案:

答案 0 :(得分:4)

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