IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Dysfonctionnement sauvegarde Base de donnée


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    151
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2002
    Messages : 151
    Points : 96
    Points
    96
    Par défaut Dysfonctionnement sauvegarde Base de donnée
    Bonjour à vous,

    J'ai un script qui sauvegarde automatiquement ma base de donnée mysql, lorsque j'ouvre ma page d'accueil de gestion de mon site web (le script crée un fichier backup.sql sur mon serveur).

    Hors, hier, j'ai travailler une nouvelle page, ajouter des champs booléen (tinyint(1) NOT NULL DEFAULT '0' ) à une table de ma base, et BAM!!! le script s'arrête lorsqu'il rencontre cette table (elle a environ 56 000) enregistrement... j'ai enlever les boolens, et BAM !!! ça refonctionne... j’avoue que je trouve ça étrange... étant donner qu'il y a des champs de même type dans beaucoup d'autre tables....

    Voici le script :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    date_default_timezone_set('America/Montreal');
     
    // Database configuration
    $host = "localhost";
    $username = "bd";
    $password = "pass";
    $database_name = "nombd";
     
    // Get connection object and set the charset
    $conn = mysqli_connect($host, $username, $password, $database_name);
    $conn->set_charset("utf8");
     
     
    // Get All Table Names From the Database
    $tables = array();
    $sql = "SHOW TABLES";
    $result = mysqli_query($conn, $sql);
     
    while ($row = mysqli_fetch_row($result)) {
        $tables[] = $row[0];
    }
     
    $sqlScript = "";
    foreach ($tables as $table) {
     
        // Prepare SQLscript for creating table structure
        $query = "SHOW CREATE TABLE $table";
        $result = mysqli_query($conn, $query);
        $row = mysqli_fetch_row($result);
     
        $sqlScript .= "\n\n" . $row[1] . ";\n\n";
     
     
        $query = "SELECT * FROM $table";
        $result = mysqli_query($conn, $query);
     
        $columnCount = mysqli_num_fields($result);
     
        // Prepare SQLscript for dumping data for each table
        for ($i = 0; $i < $columnCount; $i ++) {
            while ($row = mysqli_fetch_row($result)) {
                $sqlScript .= "INSERT INTO $table VALUES(";
                for ($j = 0; $j < $columnCount; $j ++) {
                    $row[$j] = $row[$j];
     
                    if (isset($row[$j])) {
                        $sqlScript .= '"' . $row[$j] . '"';
                    } else {
                        $sqlScript .= '""';
                    }
                    if ($j < ($columnCount - 1)) {
                        $sqlScript .= ',';
                    }
                }
                $sqlScript .= ");\n";
            }
        }
     
        $sqlScript .= "\n"; 
     
    }
     
     
    if(!empty($sqlScript))
    {
        // Save the SQL script to a backup file
        $backup_file_name = 'backup/backup_' . date("Y-m-d H i s") . '.sql';
        $fileHandler = fopen($backup_file_name, 'w+');
        $number_of_lines = fwrite($fileHandler, $sqlScript);
        fclose($fileHandler); 
     
     
    }
    Avez-vous une idée ?

    Merci beaucoup,

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 420
    Points : 15 789
    Points
    15 789
    Par défaut
    le script s'arrête où ? montrez-nous tout le débugage.

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    151
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2002
    Messages : 151
    Points : 96
    Points
    96
    Par défaut
    Bonjour,

    J'ai fait quelques test se matin..

    Le script s'arrête sur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for ($j = 0; $j < $columnCount; $j ++)
    Seulement, lorsqu'il rencontre une table spécifique, qui a 20 colonnes, 56 000 enregistrement environs, et fait environ 5.5mo.

    Si dans le code je remplace columnCount par une valeur plus petite, genre 8, le script fonctionne bien, si je mets 10 ou plus il s’arrête...

    J'ai des tables qui on 26 colonnes, et sur laquelle le script marche bien, mais avec 300 enregistrement et ça marche.

    Les pages web, et base de donnée sont héberger sur un serveur distant, j'ai aucun accès au configuration server.

    J'imagine donc, qu'il faudra que je me penche sur l'optimisation des tables etc.. qui à faire des tables plus petites...

  4. #4
    Membre émérite Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 896
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 896
    Points : 2 838
    Points
    2 838
    Par défaut
    Bonjour,

    Il faudrait consulter les logs d'erreur afin de savoir pourquoi le script s'est arrêté et nous transmettre les logs


    Sinon, pourquoi ne pas plutôt utiliser une CRON qui lancerait un mysqldump tous les jours ?
    Ca serait beaucoup plus rapide, moins couteux en ressource et mysqldump est fait spécialement pour les backups de database ^^

    mysqldump -u username_de_la_db -pmot_de_passe nom_de_la_base > nom_du_fichier.sql

Discussions similaires

  1. Sauvegarde base de données SQL 2000
    Par fredjl dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 07/09/2007, 09h52
  2. sauvegarde base et données mysql
    Par chris81 dans le forum Administration
    Réponses: 7
    Dernier message: 16/03/2007, 16h13
  3. Sauvegarde base de données MYSQL
    Par Viau dans le forum Administration
    Réponses: 28
    Dernier message: 11/06/2006, 18h04
  4. Sauvegarde base de donnée
    Par jmde dans le forum Access
    Réponses: 4
    Dernier message: 08/03/2006, 18h53
  5. [MySQL] Sauvegarde base de données en XML
    Par Ben42 dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 15/02/2006, 12h37

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo