Я хотел бы динамически переключаться с базы данных на другую, имя которой было динамически задано пользователем.
Вот некоторые значимые фрагменты моего кода:
//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, который предпочитает использовать жестко закодированное значение.
Для тех, кто заинтересован в ответе, вот он.
Хитрость довольно проста: поскольку я не хотел, чтобы мои 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');
Других решений пока нет …