Skip to content
Snippets Groups Projects
Select Git revision
  • 16ab6d3042a20e92c1a1aacd5917cf1e56cd044f
  • master default protected
  • php84
  • ll-api-test
  • 6.x
  • release_6.2.0
  • modif_maintenance_phtml
  • 6.0.x
  • detached2
  • detached
  • php82
  • feature_SearchAndSelectFilter
  • 5.x
  • 4.x
  • 7.2.1
  • 7.2.0
  • 6.2.0
  • 7.1.0
  • 7.0.0
  • 1.1.1
  • 6.1.7
  • 6.1.6
  • 6.1.5
  • 6.0.16
  • 6.0.15
  • 6.1.4
  • 6.0.14
  • 6.1.3
  • 6.0.13
  • 6.1.2
  • 6.0.12
  • 6.1.1
  • 6.1.0
  • 6.0.11
34 results

Module.php

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    DelDbStructure.php 2.97 KiB
    <?php
    
    /**
     * @var $this       \Application\View\Renderer\PhpRenderer
     * @var $controller \Zend\Mvc\Controller\AbstractController
     * @var $viewName   string
     * @var $sl         \Zend\ServiceManager\ServiceLocatorInterface
     */
    
    use Application\Constants;
    use Doctrine\ORM\EntityManager;
    use UnicaenCode\Console;
    
    if (!isset($_SERVER['argv']) || !in_array('bdd=deploy', $_SERVER['argv'])) {
        Console::println("Attention : l'opération DOIT se dérouler sur la base de déploiement!!\n", null, Console::BG_RED);
        die();
    }
    
    Console::printMainTitle('Suppression totale de contenu de schéma de BDD');
    
    /** @var EntityManager $em */
    $em = $sl->get(Constants::BDD);
    
    $schema = strtoupper($em->getConnection()->getSchemaManager()->getSchemaSearchPaths()[0]);
    
    $queries = [
        'Suppression des triggers'  =>
            "SELECT 'DROP TRIGGER ' || trigger_name dsql FROM ALL_TRIGGERS WHERE owner='$schema'",
        'Suppression des séquences' =>
            "SELECT 'DROP SEQUENCE ' || sequence_name dsql FROM ALL_SEQUENCES WHERE sequence_owner='$schema'",
    
        'Suppression des contraintes' =>
            "SELECT 'ALTER TABLE ' || table_name || ' DROP CONSTRAINT ' || constraint_name dsql
            FROM ALL_CONSTRAINTS WHERE owner='$schema' AND constraint_type = 'R'",
    
        'Suppression des vues' =>
            "SELECT 'DROP VIEW ' || view_name dsql FROM ALL_VIEWS WHERE owner = '$schema'",
    
        'Suppression des vues matérialisées' =>
            "SELECT 'DROP MATERIALIZED VIEW ' || mview_name dsql FROM ALL_MVIEWS WHERE owner = '$schema'",
    
        'Suppression des packages' =>
            "SELECT 'DROP PACKAGE ' || object_name dsql FROM USER_OBJECTS WHERE object_type = 'PACKAGE'",
    
        'Suppression des tables' =>
            "SELECT 'DROP TABLE ' || table_name dsql FROM ALL_TABLES WHERE owner='$schema'",
    
        'Suppression des index restants' =>
            "SELECT 'DROP INDEX ' || index_name dsql FROM ALL_INDEXES WHERE owner = '$schema'",
    ];
    
    $count = 0;
    $errors = 0;
    
    foreach ($queries as $title => $query) {
        list($c,$errs) = makeExec($query, $em);
        Console::print('=> '.Console::strPad($title,40));
        Console::print($c." supprimés", Console::COLOR_GREEN);
        Console::print(', ');
        Console::print($errs." erreurs", Console::COLOR_RED);
        Console::println('.');
    
        $count += $c;
        $errors += $errs;
    }
    
    Console::print('Processus terminé : ');
    Console::print("$count éléments supprimés", Console::COLOR_GREEN);
    Console::print(', ');
    Console::print("$errors erreurs rencontrées", Console::COLOR_RED);