ThinkPHP6使用.env配置数据库配置文件database.php的使用
发表于:2023-01-09 12:46:32浏览:4090次
通过ThinkPHP6官方的使用手册了解到,TP6提供了测试环境使用的.env文件。在有.env(可以通过example.env修改)文件的时候框架会优先读取.env文件作为数据库的配置,默认读取[DATABASE]。
场景一:
在不设置.env文件时,默认读取database.php配置的第一个配置。
//数据库连接配置信息
'connections' => [
'mysgl' =>[
//数据库类型
'type' => env('database.type','mysql'),
// 服务器地址
'hostname' => env('database.hostname','127 .0 .0 .1'),
// 数据库名
'database' = => env('database.database','test'),
正确开启MYSQL和写好配置后,通过实例化模型我们能够发现模型类能够被正确实例化。
场景二
当我们数据库存在多个配置的时候,则需要指定连接参数,不然就会默认读取第一个配置。此时我们将第一个配置的连接修改为错误,第二个配置修改成正确的配置信息。

如果是一下的配置文件
此时就会默认连接到第一个配置mysql,除非此时我们的模型就要指定连接配置mysql_2,
模型类应该这样设置才能被正确实例化,这就是多库连接配置:
<?php
namespace app\model;
use think\Model;
class User extends Model
{
protected $connection = 'mysql_2';
}
场景三.env在测试环境中的使用,通过database.php配合.env文件,可以实现在开发环境和测试环境中配置的快速切换。
举个例子:如果mysql_2的
开发环境地址:119.120.60.72
本地环境地址:127.0.0.1
那么.env文件如下设置:
[MYSQL_2]
TYPE = mysql
HOSTNAME = 127.0.0.1
DATABASE = test
USERNAME = root
PASSWORD = root
HOSTPORT = 3306
CHARSET = utf8
DEBUG = true
database.php如下设置:
'mysql_2'=>[
数据库类型
'type' => env('mysql_2.type','mysql'),
// 服务器地址
'hostname' => env('mysql_2.hostname','119.120.60.72'),
// 数据库名
'database' => env('mysql_2.database','tp6'),
// 用户名
'username' => env('mysql_2.username','tp6'),
就可以实现,在本地测试环境下存在.env文件时,读取的是.env中的配置,实现快速切换。
如果需要修改env文件的加载路径,可以修改该文件:vendor\topthink\framework\src\think\App.php
的loadEnv函数
推荐文章
- Xshell提示 “要继续使用此程序,您必须应用最新的更新或使用新版本”
- thinkphp6创建并设置执行定时任务的方法
- 移动端微信、企业微信中使用H5的input file时只能选择手机的图片,不能选择文档文件的解决方案
- 十款好用到爆的 MySQL 可视化管理工具推荐
- Vue history模式下实现微信授权登录
- 82个常规的前端JavaScript方法封装(41~50)
- ThinkPHP6的前置中间件和后置中间件的区别,中间件解决跨域问题的方案
- 谷歌发布全新操作系统chromeOS Flex首个稳定版,可用于 PC 和 Mac
- Vue 3.2 刚刚发布!新的单文件组件,响应式性能大幅提升
- 移动端开发,硬件设备检测的前端方法

