DB Forge, Code Igniter и динамический выбор базы данных

Я хотел бы динамически переключаться с базы данных на другую, имя которой было динамически присвоено пользователем.

Вот некоторые значимые фрагменты моего кода:

//database.php

$active_group = 'default';
$query_builder = TRUE;

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'localhost',
    'username' => 'root',
    'password' => '',
    'database' => 'firstbase',
    '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
);

$db['newbase'] = $db['default'];

Как вы можете видеть, 'newbase' является простой копией конфигурации по умолчанию

//Install_model Model
    echo "<BR>Active db :".$this->db->database;
    $this->createDB($database);
    $this->db->close();

    //now $database is created

    //load the 'newbase' group and assign it to $this->newDb
    $this->newDb = $this->load->database('newbase', TRUE);

    //this will output 'firstbase'
    echo "<BR>so far, the active db is :".$this->newDb->database;
    $this->newDb->database=$database;
    //now this will output the $database string
    echo "<BR>and now the active db is :".$this->newDb->database;

Теперь я хочу, чтобы dbforge использовался в этой новой базе данных.

$linkfields = array(
            'table_id' => array(
                    'type' => 'VARCHAR',
                    'constraint' => '15'
            ),
            'something' => array(
                    'type' => 'VARCHAR',
                    'constraint' => '15',
                    'unique' => TRUE,
            ),
        );

        //according to the manual, we "give" our new DB to dbforge
        $this->myforge = $this->load->dbforge($this->newDb, TRUE);
        $this->myforge->add_field($linkfields);
        $this->myforge->add_key('table_id', TRUE);
        $this->myforge->create_table('Link');

Это работает, но... таблица создана в 'firstbase'! И хотя загруженная база данных - вторая. Как я могу решить это?

РЕДАКТИРОВАТЬ #1

По-видимому, $this->newDb->database=$database; не является постоянным Если связь закрыта, то вновь открыта, $this->newDb->database имеет значение, которое изначально указано в файле конфигурации базы данных. Но это не объясняет, почему я получаю эти результаты, так как я не закрываю связь.

Если я добавлю это в файл конфигурации: $db['newbase']['database'] = ''; тогда я получаю ошибку #1046: база данных не выбрана. Это подтверждает тот факт, что $this->newDb->database не используется dbforge, который предпочитает использовать жестко закодированное значение.

3 ответа

Решение

Для тех, кто заинтересован в ответе, вот он.

Хитрость довольно проста: поскольку я не хотел, чтобы мои 2 дБ были открыты одновременно, я просто использовал $ this, как будто я обрабатывал дБ по умолчанию. Давайте предположим, что в файле конфигурации у меня есть вторая группа с именем 'newbase' с пустым полем 'database'.

Пользователь дает это имя в процессе установки.

Итак, как только БД создан и соединение закрыто:

$this->load->database('newbase', True);     
$this->db->database = '$database';

использование $this->db->database для того, чтобы знать, что дБ обрабатывается.

затем объявите поля $ link, как указано выше, и просто вызовите класс dbforge:

$this->load->dbforge();
$this->dbforge->add_field($linkfields);
$this->dbforge->add_key('table_id', TRUE);  
$this->dbforge->create_table('Link');

Это то, что вам нужно:

      //database.php

$active_group = 'default';
$query_builder = TRUE;

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'localhost',
    'username' => 'root',
    'password' => '',
    'database' => 'firstbase',
    '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
);  
$db['newbase'] = $db['default'];

Затем в модели загрузите «newbase» и используйте его следующим образом:

      //model.php

$newbase = $this->load->dbforge($this->load->database('newbase', TRUE), TRUE);
$newbase->add_field($linkfields);
$newbase->add_key('table_id', TRUE);  
$newbase->create_table('Link');

Судя по нашей оценке, проблема не связана с функциональностью нашего продукта. К тому же, вы уже нашли решение проблемы.

Если проблема не устранена и связана с нашим программным обеспечением, заполните форму ниже. Предоставьте нам подробное описание проблемы и предпринятых вами действий. Кроме того, прикрепите соответствующие снимки экрана, чтобы помочь нам лучше понять проблему.

https://www.devart.com/company/contactform.html

Наши специалисты тщательно изучат этот вопрос.

Другие вопросы по тегам