ThinkPHP6使用.env配置数据库配置文件database.php的使用
发表于:2023-01-09 12:46:32浏览:4115次
通过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函数
推荐文章
- Thinkphp6集成JWT API接口引入token
- 前端常见知识点汇总——ES6篇
- 有了css变量这个神器,写css再也不需要less和sass了
- JS中三个点(...)是什么意思?其实它的真名叫“扩展运算符”
- 纯css实现左侧三级菜单的方法
- 价税合计、销项税额、发票金额 三者关系是?
- 又一轻量级的开源Linux服务器管理面板mdserver-web推荐
- ThinkPHP 6.1.2 版本发布,兼容 PHP8.2以及对ThinkORM3.0 版本的支持
- 如何在gitee上提交Pull Request,给他人的项目贡献自己的代码
- 企业微信最新的jssdk使用说明 WECOM-JSSDK Demo

