Как использовать несколько баз данных в Laravel
Я хочу объединить несколько баз данных в моей системе. Большую часть времени база данных является MySQL; но она может отличаться в будущем, т. е. администратор может генерировать такие отчеты, которые использовать источник разнородных системы баз данных.
У меня вопрос предоставляет ли Laravel какой-либо фасад справляться с такими ситуациями? Или любой другой фреймворк имеет более подходящие возможности для решения проблемы?
3 ответа:
используя
.env
> = 5.0 (проверено на 5.5)на
.env
DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=database1 DB_USERNAME=root DB_PASSWORD=secret DB_CONNECTION_SECOND=mysql DB_HOST_SECOND=127.0.0.1 DB_PORT_SECOND=3306 DB_DATABASE_SECOND=database2 DB_USERNAME_SECOND=root DB_PASSWORD_SECOND=secret
на
config/database.php
'mysql' => [ 'driver' => env('DB_CONNECTION'), 'host' => env('DB_HOST'), 'port' => env('DB_PORT'), 'database' => env('DB_DATABASE'), 'username' => env('DB_USERNAME'), 'password' => env('DB_PASSWORD'), ], 'mysql2' => [ 'driver' => env('DB_CONNECTION_SECOND'), 'host' => env('DB_HOST_SECOND'), 'port' => env('DB_PORT_SECOND'), 'database' => env('DB_DATABASE_SECOND'), 'username' => env('DB_USERNAME_SECOND'), 'password' => env('DB_PASSWORD_SECOND'), ],
Примечание: In
mysql2
если DB_username и DB_password одинаковы, то вы можете использоватьenv('DB_USERNAME')
, который упоминается в.env
первые несколько строк.без
.env
Определения Соединений
app/config/database.php
return array( 'default' => 'mysql', 'connections' => array( # Primary/Default database connection 'mysql' => array( 'driver' => 'mysql', 'host' => '127.0.0.1', 'database' => 'database1', 'username' => 'root', 'password' => 'secret' 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', ), # Secondary database connection 'mysql2' => array( 'driver' => 'mysql', 'host' => '127.0.0.1', 'database' => 'database2', 'username' => 'root', 'password' => 'secret' 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', ), ), );
- схемы
чтобы указать, какое соединение использовать, просто запустите
connection()
методSchema::connection('mysql2')->create('some_table', function($table) { $table->increments('id'): });
Конструктор Запросов
$users = DB::connection('mysql2')->select(...);
красноречивое
установить
$connection
переменной в модельclass SomeModel extends Eloquent { protected $connection = 'mysql2'; }
вы также можете определить соединение во время выполнения через
setConnection
способ илиon
статический метод:class SomeController extends BaseController { public function someMethod() { $someModel = new SomeModel; $someModel->setConnection('mysql2'); // non-static method $something = $someModel->find(1); $something = SomeModel::on('mysql2')->find(1); // static method return $something; } }
Примечание будьте осторожны при попытке построить отношения с таблицами в разных базах данных! Это можно сделать, но он может прийти с некоторыми оговорками и зависит от того, какая база данных и/или настройки базы данных у вас есть.
От Laravel Документы
Использование Нескольких Подключений К Базе Данных
при использовании нескольких соединений, вы можете получить доступ к каждому
connection
через метод соединения наDB
фасад. Элементname
перешло кconnection
метод должен соответствовать одному из соединений, перечисленных вconfig/database.php
конфигурационный файл:$users = DB::connection('foo')->select(...);
вы можете получить доступ к необработанный базовый экземпляр PDO с использованием метода getPdo на экземпляре соединения:
$pdo = DB::connection()->getPdo();
Полезные Ссылки
в Laravel 5.1 вы указываете соединение:
$users = DB::connection('foo')->select(...);
по умолчанию Laravel использует соединение по умолчанию. Это просто, не так ли?
Подробнее читайте здесь:http://laravel.com/docs/5.1/database#accessing-connections
на самом деле
DB::connection('name')->select(..)
не работает для меня, потому что " имя " должно быть в двойных кавычках:"имя"тем не менее, запрос select выполняется на моем соединении по умолчанию. Все еще пытаюсь понять, как убедить Laravel работать так, как он предназначен: изменить соединение.
Edit:я понял это. После отладки Laravels DatabaseManager получилась моя база данных.php (файл конфигурации) (внутри $this->app) был неправильным. В разделе "соединения" у меня были такие вещи, как " база данных" со значениями того, из которого я его скопировал. В понятных выражениях, а не
env('DB_DATABASE', 'name')
мне нужно было разместить что-то вроде
'myNewName'
так как все соединения были указаны те же значения для базы данных, имя пользователя, пароль и т. д. что, конечно, имеет мало смысла, если я хочу получить доступ хотя бы к другому имени базы данных
поэтому каждый раз, когда я хотел выбрать что-то из другой базы данных, я всегда оказался в моей базе данных по умолчанию