tp5实现多数据库查询

简介:

引言:

有时候一个管理后台,需要涉及到多个数据库。比如,商城管理、直播管理、消息管理等等,它们都有自己的数据库。这个时候,就需要去连接多个数据库,进行处理了。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 app\admin\model;
use think\Model;
use think\Db;
class LiveRecharge extends Model
{
    protected $db_app;
    function __construct()
    {
        $this->db_app = Db::connect('database_app');
    }
 }

3.使用

$this->db_app->table('order')->select();

这样就可以查询其他数据库中的数据了。
下面是全的代码:

<?php

namespace app\admin\model;
use think\Model;
use think\Db;
class LiveRecharge extends Model
{
    protected $db_app;
    function __construct()
    {
        $this->db_app = Db::connect('database_app');
    }

    // 获取分页
    public function getList($customer_id = '',$nickname = '',$paytime = '',$pagesize = '')
    {
        $pagesize = $pagesize && $pagesize > 0 ? $pagesize : config('default_page_size');

        $where = array();

        $where['o.type'] = 3;

        if ($customer_id) {
            $where['o.uid'] = $customer_id;
        }

        if ($nickname) {
            $where['c.NickName'] = ['like','%'.$nickname.'%'];
        }

        if ($paytime) {
            $where['o.addtime'] = array(['>',$paytime.' 00:00'], ['<',$paytime.' 23:59']);
        }

        $result = $this->db_app->table('order')
            ->alias('o')
            ->where($where)
            ->join('customer c','o.uid = c.Id')
            ->field('o.*,c.NickName as nickname')->paginate($pagesize,false,[
                'query' => [
                    'customer_id'=>$customer_id,
                    'nickname'=>$nickname,
                    'paytime'=>$paytime
                ]
            ]);

        $page = $result->render(); // 分页
        $data = $result->all(); // 数据

        foreach ($data as $k=>$v) {
            $data[$k]['diamond'] = intval($v['money'])*10;
        }

        //        dump($this->db_app->getLastSql());

        $total_diamond = $this->db_app->table('order')->where('type',3)->sum('money*10');
        $outData['page'] = $page;
        $outData['data'] = $data;
        $outData['total_diamond'] = $total_diamond;
        return $outData;
    }
}

小结:灵活运用model层,灵活的查询数据。

学会组织语言,学会撰写文档,学会归纳总结。



本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/7649830.html,如需转载请自行联系原作者

相关文章
|
4月前
|
人工智能 安全 机器人
无代码革命:10分钟打造企业专属数据库查询AI机器人
随着数字化转型加速,企业对高效智能交互解决方案的需求日益增长。阿里云AppFlow推出的AI助手产品,借助创新网页集成技术,助力企业打造专业数据库查询助手。本文详细介绍通过三步流程将AI助手转化为数据库交互工具的核心优势与操作指南,包括全场景适配、智能渲染引擎及零代码配置等三大技术突破。同时提供Web集成与企业微信集成方案,帮助企业实现便捷部署与安全管理,提升内外部用户体验。
502 12
无代码革命:10分钟打造企业专属数据库查询AI机器人
|
6月前
|
Cloud Native 关系型数据库 分布式数据库
|
6月前
|
并行计算 关系型数据库 MySQL
如何用 esProc 将数据库表转储提速查询
当数据库查询因数据量大或繁忙变慢时,可借助 esProc 将数据导出为文件进行计算,大幅提升性能。以 MySQL 的 3000 万行订单数据为例,两个典型查询分别耗时 17.69s 和 63.22s。使用 esProc 转储为二进制行存文件 (btx) 或列存文件 (ctx),结合游标过滤与并行计算,性能显著提升。例如,ctx 并行计算将原查询时间缩短至 0.566s,TopN 运算提速达 30 倍。esProc 的简洁语法和高效文件格式,特别适合历史数据的复杂分析场景。
|
7月前
|
SQL 关系型数据库 MySQL
如何优化SQL查询以提高数据库性能?
这篇文章以生动的比喻介绍了优化SQL查询的重要性及方法。它首先将未优化的SQL查询比作在自助餐厅贪多嚼不烂的行为,强调了只获取必要数据的必要性。接着,文章详细讲解了四种优化策略:**精简选择**(避免使用`SELECT *`)、**专业筛选**(利用`WHERE`缩小范围)、**高效联接**(索引和限制数据量)以及**使用索引**(加速搜索)。此外,还探讨了如何避免N+1查询问题、使用分页限制结果、理解执行计划以及定期维护数据库健康。通过这些技巧,可以显著提升数据库性能,让查询更高效流畅。
|
7月前
|
数据库 Python
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
|
7月前
|
数据库
【YashanDB知识库】数据库用户所拥有的权限查询
【YashanDB知识库】数据库用户所拥有的权限查询
|
7月前
|
存储 运维 监控
百万指标,秒级查询,零宕机——时序数据库 TDengine 在 AIOps 中的硬核实战
本篇文章详细讲述了七云团队在运维平台中如何利用 TDengine 解决海量时序数据存储与查询的实际业务需求。内容涵盖了从数据库选型、方案落地到业务挑战及解决办法的完整过程,特别是分享了升级 TDengine 3.x 时的实战经验,给到有需要的小伙伴参考阅读。
242 1
|
7月前
|
缓存 NoSQL 关系型数据库
WordPress数据库查询缓存插件
这款插件通过将MySQL查询结果缓存至文件、Redis或Memcached,加速页面加载。它专为未登录用户优化,支持跨页面缓存,不影响其他功能,且可与其他缓存插件兼容。相比传统页面缓存,它仅缓存数据库查询结果,保留动态功能如阅读量更新。提供三种缓存方式选择,有效提升网站性能。
125 1
|
7月前
|
数据库

热门文章

最新文章