如何動態更改database

假設有個情況,有10間分工廠的金流帳簿的database分別是 accountbook01 到 accountbook10,而且每間分工廠的database的結構一模一樣。
請教各位先進,在 larvel 10 使用什麼方法或函式可以立即動態換切要查詢的database?

以下是測式範例用的設定:

.env檔案節錄

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=accountbook01
DB_USERNAME=root
DB_PASSWORD=

Model檔案節錄

class Accountbook_model extends Model {

/*
* 索取指定月份細則
*/
/*
* 如要把database從accountbook01切換成accountbook07,如何做?
*/
    static public function get_month_content($id) {
        $result = \DB::select("SELECT * FROM monthlist WHERE id=?", [$id]);
        return $result;
    }
}
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 4

config/database.php新增一个数据库配置

'mysql2' => [
    'driver' => 'mysql',
    'host' => env('DB_HOST2', '127.0.0.1'),
    'port' => env('DB_PORT2', '3306'),
    'database' => env('DB_DATABASE2', 'forge'),
    'username' => env('DB_USERNAME2', 'forge'),
    'password' => env('DB_PASSWORD2', ''),
    // ...
],

DB::setDefaultConnection('mysql2'); 之后的所有数据库操作都将使用这个新的数据库连接

如果只是临时切换,用DB::connection('mysql2')

5个月前 评论

这个简单,模型不是有个作用域函数么,在里面重新传入需要使用的模型,就可以达到动态改变表

5个月前 评论
sanders

像楼主代码中这样直接查询的话,见手册这里:快速入门《Laravel 10 中文文档》

5个月前 评论

file 先设置一个mysql_node连接,然后可以通过中间动态切换数据库

5个月前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!