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

前端之家收集整理的这篇文章主要介绍了为什么MySQL Workbench会为视图生成占位符表?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

在我在MySQL Workbench中创建的数据库模型中,我定义了一个视图.当我现在从diagramm(菜单 – >数据库 – >正向工程师或Ctrl 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;

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

谢谢

最佳答案
占位符(不仅由WB而且由例如MysqLdump)创建以解决循环引用.视图定义可以引用一个需要视图的表(或一个表,该表需要一个表,该表需要一个最终需要初始视图的视图).这不能自动检测也不能解决,除非通过定义虚拟视图(暂时作为表,因为视图在大多数方面如表),然后在所有其他对象可用时重新定义它们.
原文链接:https://www.f2er.com/mysql/433130.html

猜你在找的MySQL相关文章