Резервное копирование базы данных не работает в codeignator с использованием pdo - PullRequest
0 голосов
/ 22 февраля 2019

Я получаю указанную ниже ошибку при использовании приведенного ниже кода резервной копии базы данных в драйвере codeigniter pdo:

$this->load->dbutil();
$prefs = array(
    'format' => 'zip', // gzip, zip, txt
    'filename' => 'backup_' . date('m_d_Y_H_i_s') . '.sql', // File name - NEEDED ONLY WITH ZIP FILES
    'add_drop' => TRUE, // Whether to add DROP TABLE statements to backup file
    'add_insert' => TRUE, // Whether to add INSERT data to backup file
    'newline' => "\n"               // Newline character used in backup file
);
$backup = $this->dbutil->backup($prefs);

$this->load->helper('file');
write_file('/path/to/' . 'dbbackup_' . date('m_d_Y_H_i_s') . '.zip', $backup);
$this->load->helper('download');
force_download('dbbackup_' . date('m_d_Y_H_i_s') . '.zip', $backup);

Неподдерживаемая функция используемой платформы базы данных.

Имя файла: E: /xampp/htdocs/pvr/system/database/drivers/pdo/pdo_utility.php

Номер строки: 60

На сервере MySQL, используя этот код, яполучаю резервную копию базы данных, но в pdo получаю эту ошибку, поэтому, пожалуйста, помогите мне получить резервную копию базы данных в драйвере pdo

1 Ответ

0 голосов
/ 25 марта 2019
  1. Подтвердите, что pdo mysql включен в php ini

  2. правильно проверьте код из https://www.codeigniter.com/userguide3/database/utilities.html?

https://www.codeigniter.com/userguide3/database/configuration.html?

попробуйте этот код, он работает на 100%

controller / DATABASE_BACKUP.php

<?php
    class DATABASE_BACKUP extends CI_Controller {

        public function index()
        {
            $this->load->database();

            // Load the DB utility class
            $this->load->dbutil();

            // Backup your entire database and assign it to a variable
            $backup = $this->dbutil->backup();

            // Load the file helper and write the file to your server
            $this->load->helper('file');
            write_file('mybackup.gz', $backup);

            // Load the download helper and send the file to your desktop
            $this->load->helper('download');
            //force_download('mybackup.gz', $backup);
        }
    }
?>

моя конфигурация базы данных config / database.php

<?php
    $active_group = 'default';
    $query_builder = TRUE;

    $db['default'] = array(
        'dsn'   => '',
        'hostname' => 'localhost',
        'username' => 'root',
        'password' => '',
        'database' => 'faker_db',
        'dbdriver' => 'mysqli',
        'dbprefix' => '',
        'pconnect' => FALSE,
        'db_debug' => (ENVIRONMENT !== 'production'),
        'cache_on' => FALSE,
        'cachedir' => '',
        'char_set' => 'utf8',
        'dbcollat' => 'utf8_general_ci',
        'swap_pre' => '',
        'encrypt' => FALSE,
        'compress' => FALSE,
        'stricton' => FALSE,
        'failover' => array(),
        'save_queries' => TRUE 
    );
?>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...