tp5(thinkPHP5)框架实现多数据库查询的方法

2023-02-20 15:04:18 浏览数 (1)

有时候一个管理后台,需要涉及到多个数据库。比如,商城管理、直播管理、消息管理等等,它们都有自己的数据库。这个时候,就需要去连接多个数据库,进行处理了。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)框架实现多数据库查询的方法

0 人点赞