Files
geo/api/scripts/php/migrate_x_departements.php
pierre 1018b86537 feat: Gestion des secteurs et migration v3.0.4+304
- Ajout système complet de gestion des secteurs avec contours géographiques
- Import des contours départementaux depuis GeoJSON
- API REST pour la gestion des secteurs (/api/sectors)
- Service de géolocalisation pour déterminer les secteurs
- Migration base de données avec tables x_departements_contours et sectors_adresses
- Interface Flutter pour visualisation et gestion des secteurs
- Ajout thème sombre dans l'application
- Corrections diverses et optimisations

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-07 11:01:45 +02:00

88 lines
2.9 KiB
PHP
Executable File

<?php
/**
* Script de migration pour la table x_departements
* Transfert les données de la base source (geosector) vers la base cible (geosector_app)
*/
require_once dirname(__DIR__) . '/config.php';
try {
// Création du tunnel SSH si nécessaire
createSshTunnel();
// Connexion aux bases de données
$sourceDb = getSourceConnection();
$targetDb = getTargetConnection();
// Récupération des départements depuis la base source
$stmt = $sourceDb->query("SELECT * FROM x_departements");
$departements = $stmt->fetchAll(PDO::FETCH_ASSOC);
echo "Nombre de départements à migrer: " . count($departements) . PHP_EOL;
// Préparation de la requête d'insertion
$insertQuery = "INSERT INTO x_departements (
id,
code,
fk_region,
libelle,
chk_active
) VALUES (
:id,
:code,
:fk_region,
:libelle,
:chk_active
) ON DUPLICATE KEY UPDATE
code = VALUES(code),
fk_region = VALUES(fk_region),
libelle = VALUES(libelle),
chk_active = VALUES(chk_active)";
$insertStmt = $targetDb->prepare($insertQuery);
// Compteurs
$successCount = 0;
$errorCount = 0;
// Traitement de chaque département
foreach ($departements as $departement) {
try {
// Mappage des champs entre les deux structures
$id = isset($departement['rowid']) ? $departement['rowid'] : $departement['id'];
$chkActive = isset($departement['active']) ? $departement['active'] :
(isset($departement['chk_active']) ? $departement['chk_active'] : 1);
// Préparation des données pour l'insertion
$departementData = [
'id' => $id,
'code' => $departement['code'],
'fk_region' => $departement['fk_region'],
'libelle' => $departement['libelle'],
'chk_active' => $chkActive
];
// Insertion dans la base cible
$insertStmt->execute($departementData);
$successCount++;
} catch (Exception $e) {
$errorCount++;
echo "Erreur lors de la migration du département ID {$id}: " . $e->getMessage() . PHP_EOL;
}
}
echo "Migration terminée. Succès: $successCount, Erreurs: $errorCount" . PHP_EOL;
// Fermer le tunnel SSH
closeSshTunnel();
} catch (Exception $e) {
echo "Erreur critique: " . $e->getMessage() . PHP_EOL;
// Fermer le tunnel SSH en cas d'erreur
closeSshTunnel();
exit(1);
}