有时候一个管理后台,需要涉及到多个数据库。比如,商城管理、直播管理、消息管理等等,它们都有自己的数据库。这个时候,就需要去连接多个数据库,进行处理了。thinkphp可以支持多个数据库连接。
如何处理呢?
1.进行多个数据库的配置
默认会连接database.php中的数据库信息。
<?php
// ———————————————————————-
// | ThinkPHP WE CAN DO IT JUST THINK
// ———————————————————————-
// | Copyright (c) 2006~2016 http://thinkphp.cn All rights reserved.
// ———————————————————————-
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// ———————————————————————-
// | Author: liu21st liu21st@gmail.com
// ———————————————————————-
return [
// 数据库类型
‘type’ => ‘mysql’,
// 服务器地址
‘hostname’ => ”,
// 数据库名
‘database’ => ”,
// 数据库用户名
‘username’ => ”,
// 数据库密码
‘password’ => ”,
// 数据库连接端口
‘hostport’ => ‘3306’,
// 数据库编码默认采用utf8
‘charset’ => ”,
// 数据库表前缀
‘prefix’ => ”
];
tp5会自动加载database.php
我们可以在extra文件夹中,再创建几个其他数据库的配置,比如database_mall,database_live,database_app等。
2.初始化
在model模块中进行初始化
<?php
namespace appadminmodel;
use thinkModel;
use thinkDb;
class LiveRecharge extends Model
{
protected $db_app;
function __construct()
{
$this->db_app = Db::connect(‘database_app’);
}
}
3.使用
$this->db_app->table(‘order’)->select();
这样就可以查询其他数据库中的数据了。
另外在控制器里直接查询的话也可以这样写:
代码语言:javascript复制$list=Db::connect('database_ttkj')->name('user')->order('id desc')->select();
此时读取的是extra文件夹中的database_ttkj.php 文件
小结:灵活运用model层,灵活的查询数据。
学会组织语言,学会撰写文档,学会归纳总结。
————————————————
版权声明:本文为CSDN博主「宇凡网络」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq19124152/article/details/122185315
未经允许不得转载:肥猫博客 » tp5(thinkPHP5)框架实现多数据库查询的方法