博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Laravel 使用多个数据库的问题。
阅读量:6579 次
发布时间:2019-06-24

本文共 1999 字,大约阅读时间需要 6 分钟。

这几天在使用Laravel 开发一个系统。这个系统连2个数据库。一个名为blog,一个名为center。

center 数据库的作用是作为用户中心。可能会有其他几个系统相连,属于公用数据库。主要是用来用户登录认证。
blog 数据库的作用是放文章,不会牵扯到认证方面。

我的想法是使用center数据库作为用户的登录认证,登录以后在发文章切换到blog数据库。

目前我的.env配置如下

DB_HOST=localhostDB_DATABASE=blogDB_DATABASE_CENTER=center DB_USERNAME=root DB_PASSWORD=root

database.php 里设计如下

'mysql' => [        'driver'    => 'mysql',        'host' => env('DB_HOST', 'localhost'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', 'strict' => false, ], 'mysql_center' => [ 'driver' => 'mysql', 'host' => env('DB_HOST', 'localhost'), 'database' => env('DB_DATABASE_CENTER', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', 'strict' => false, ],

我自己建立的model User.php 是可以通过下面这种方式切换数据库的。

class User extends Model implements AuthenticatableContract, CanResetPasswordContract { protected $connection = 'mysql_center';

但是系统自带的例子Controller 要怎么切换数据库呢?

app\Http\Controllers\Auth\AuthController.phpapp\Http\Controllers\Auth\PasswordController.php

希望大家能帮忙解答一下,谢谢!

  • 邀请回答
  • 编辑
 

4个回答

 

0

已采纳

看看文档:

AuthController 默认是使用 “App\User” Eloquent model, 同样的, 你在App\User里指定某一个数据库就是了

  • 编辑
 

0

补充一下 laravel 5 自带的 Auth 案例里实现的登录注册和密码找回两个部分。

对于注册登录部分 可以使用ylem的方法。

对于密码找回,需要在/config/auth.php里面进行设置。

例如:

'table' => 'mydatabases.password_resets',
  • 编辑
 

0

'host'      => env('DB_HOST', 'localhost'),    'database' => env('DB_DATABASE_CENTER', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', ==================写法错误……去掉env , env('DB_DATABASE_CENTER', 'forge')只留下'forge', env('DB_PASSWORD', ''),只留下 '' /* 我了解决这个问题,作为一个新手,我耗费了累计时间 两天 */
  • ·
  • 编辑
 

0

在控制器里这样写

 
$results = DB::connection('mysql')->select('...'); $results = DB::connection('mysql_center')->select('...');

转载地址:http://cmyno.baihongyu.com/

你可能感兴趣的文章
controller中,Failed to Initialize. Reason: TimeOut虚拟用花初始化超时
查看>>
Blend4精选案例图解教程(四):请给我路径指引
查看>>
c#之第三课
查看>>
部署tinyproxy代理服务
查看>>
Github Page 绑定域名
查看>>
排序(杭电1106)
查看>>
【微服务干货系列】使用微服务架构之前,你必须知道的
查看>>
SDUST 2844-Mineral Water(数学)
查看>>
我的第一个开源控件-DragGridView
查看>>
5 Protocols For Event-Driven API Architectures
查看>>
Git篇
查看>>
Navicat for MySQL 使用SSH方式链接远程数据库(二)
查看>>
Linux常用基本命令( mkdir )
查看>>
JS原型 原型链
查看>>
maven打包时跳过测试
查看>>
Wix 安装部署教程(十) --来,用WPF做个漂亮的安装界面
查看>>
WPF 窗口居中 & 变更触发机制
查看>>
php标准库spl栈SplStack如何使用?
查看>>
机器学习新手使用入门
查看>>
详解Spring Boot集成MyBatis的开发流程
查看>>