@@ 675-698 (lines=24) @@ | ||
672 | * @param string $viewName Name of view to export |
|
673 | * @return null |
|
674 | */ |
|
675 | private function getViewStructureTable($viewName) |
|
676 | { |
|
677 | if (!$this->dumpSettings['skip-comments']) { |
|
678 | $ret = "--" . PHP_EOL . |
|
679 | "-- Stand-In structure for view `${viewName}`" . PHP_EOL . |
|
680 | "--" . PHP_EOL . PHP_EOL; |
|
681 | $this->compressManager->write($ret); |
|
682 | } |
|
683 | $stmt = $this->typeAdapter->show_create_view($viewName); |
|
684 | ||
685 | // create views as tables, to resolve dependencies |
|
686 | foreach ($this->dbHandler->query($stmt) as $r) { |
|
687 | if ($this->dumpSettings['add-drop-table']) { |
|
688 | $this->compressManager->write( |
|
689 | $this->typeAdapter->drop_view($viewName) |
|
690 | ); |
|
691 | } |
|
692 | ||
693 | $this->compressManager->write( |
|
694 | $this->createStandInTable($viewName) |
|
695 | ); |
|
696 | break; |
|
697 | } |
|
698 | } |
|
699 | ||
700 | /** |
|
701 | * Write a create table statement for the table Stand-In, show create |
|
@@ 727-749 (lines=23) @@ | ||
724 | * @param string $viewName Name of view to export |
|
725 | * @return null |
|
726 | */ |
|
727 | private function getViewStructureView($viewName) |
|
728 | { |
|
729 | if (!$this->dumpSettings['skip-comments']) { |
|
730 | $ret = "--" . PHP_EOL . |
|
731 | "-- View structure for view `${viewName}`" . PHP_EOL . |
|
732 | "--" . PHP_EOL . PHP_EOL; |
|
733 | $this->compressManager->write($ret); |
|
734 | } |
|
735 | $stmt = $this->typeAdapter->show_create_view($viewName); |
|
736 | ||
737 | // create views, to resolve dependencies |
|
738 | // replacing tables with views |
|
739 | foreach ($this->dbHandler->query($stmt) as $r) { |
|
740 | // because we must replace table with view, we should delete it |
|
741 | $this->compressManager->write( |
|
742 | $this->typeAdapter->drop_view($viewName) |
|
743 | ); |
|
744 | $this->compressManager->write( |
|
745 | $this->typeAdapter->create_view($r) |
|
746 | ); |
|
747 | break; |
|
748 | } |
|
749 | } |
|
750 | ||
751 | /** |
|
752 | * Trigger structure extractor |