Yii2在运行时设置数据库连接

And*_*ger 3 php database dynamic yii2

在我的Yii2(基本应用程序)web.php中,我将NULL数据库连接配置为第二个数据库连接.

这需要填充来自主数据库连接上的记录的有效参数:

'db' => require(__DIR__ . '/db.php'),
'db2' => [
    'class' => 'yii\db\Connection',
    'dsn' => NULL,
    'username' => NULL,
    'password' => NULL,
    'charset' => 'utf8',
],
Run Code Online (Sandbox Code Playgroud)

在初始化app()之后,我需要使用从另一个数据库检索的值来填充NULL参数,以便在模型中进一步使用它.

我怎样才能在Yii2中实现这一目标?

Ngô*_*hao 8

没问题,它是支持的

\Yii::$app->db2->close(); // make sure it clean
\Yii::$app->db2->dsn= 'yourdsn';
\Yii::$app->db2->username = 'username';
\Yii::$app->db2->password = 'password';
Run Code Online (Sandbox Code Playgroud)

完成,现在你可以使用它

Yii::$app->db2->...
Run Code Online (Sandbox Code Playgroud)

其他方式:

$connection = new \yii\db\Connection([
    'dsn' => $dsn,
    'username' => $username,
    'password' => $password,
]);
$connection->open();
$command = $connection->createCommand('SELECT * FROM post')->....;
Run Code Online (Sandbox Code Playgroud)

请参阅:http://www.yiiframework.com/doc-2.0/yii-db-connection.html