国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

tp5(thinkPHP5)框架實現多數據庫查詢的方法

2024-05-05 00:06:10
字體:
來源:轉載
供稿:網友

本文實例講述了tp5(thinkPHP5)框架實現多數據庫查詢的方法。分享給大家供大家參考,具體如下:

引言:

有時候一個管理后臺,需要涉及到多個數據庫。比如,商城管理、直播管理、消息管理等等,它們都有自己的數據庫。這個時候,就需要去連接多個數據庫,進行處理了。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模塊中進行初始化

<?phpnamespace 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();

這樣就可以查詢其他數據庫中的數據了。

下面是全的代碼:

<?phpnamespace 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層,靈活的查詢數據。

學會組織語言,學會撰寫文檔,學會歸納總結。

希望本文所述對大家基于ThinkPHP框架的PHP程序設計有所幫助。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 道孚县| 砀山县| 大同市| 星座| 汪清县| 民权县| 信丰县| 三原县| 阳山县| 全椒县| 云阳县| 临沂市| 伊吾县| 莒南县| 仁化县| 太仆寺旗| 曲靖市| 仪征市| 乐业县| 高雄县| 阿鲁科尔沁旗| 太保市| 乐清市| 铁力市| 福鼎市| 泰兴市| 安康市| 宣武区| 武山县| 尖扎县| 黎平县| 庐江县| 田阳县| 松阳县| 罗江县| 綦江县| 杨浦区| 日照市| 南阳市| 高州市| 涿州市|