微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 在Laravel中动态更改数据库连接

我有数据库,每个用户都有登录表和相应的数据库设置.在登录时,我应该动态更改从表中获取数据库设置.
我可以更改数据库连接,但这不是持久的.

Config::set("database.connections.MysqL", [
'driver' => 'MysqL',
"host" => $usr_host,
"database" => $usr_database,
"username" => $usr_username,
"password" => $usr_password,
...
]);

编辑:
当他/她向应用程序注册时,为每个用户创建新数据库,因此我没有为config / database.PHP中定义的每个用户建立数据库连接.

解决方法:

那么你可以使用数据库进行用户登录,并为数据库名称设置一个新字段.然后,只要您需要查询其他数据库,就可以更改数据库连接.

像这样的东西

$someModel = new SomeModel;
$databaseName = "MysqL2"; // Dynamically get this value from db
$someModel->setConnection($databaseName);
$something = $someModel->find(1);

你可以在这里读更多关于它的内容.
http://fideloper.com/laravel-multiple-database-connections

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐