溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用ThinkPHP怎么連接數(shù)據(jù)庫(kù)并設(shè)置主從

發(fā)布時(shí)間:2021-03-04 14:46:04 來(lái)源:億速云 閱讀:159 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)使用ThinkPHP怎么連接數(shù)據(jù)庫(kù)并設(shè)置主從,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

thinkphp是什么

thinkphp屬于一種免費(fèi)的開(kāi)發(fā)框架,能夠用于開(kāi)發(fā)前端網(wǎng)頁(yè),最早thinkphp是為了簡(jiǎn)化開(kāi)發(fā)而產(chǎn)生的,thinkphp同時(shí)也是遵循Apache2協(xié)議,最初是從Struts演變過(guò)來(lái),也把國(guó)外一些好的框架模式進(jìn)行利用,使用面向?qū)ο蟮拈_(kāi)發(fā)結(jié)構(gòu),兼容了很多標(biāo)簽庫(kù)等模式,它能夠更方便和快捷的開(kāi)發(fā)和部署應(yīng)用,當(dāng)然不僅僅是企業(yè)級(jí)應(yīng)用,任何php應(yīng)用開(kāi)發(fā)都可以從thinkphp的簡(jiǎn)單、兼容和快速的特性中受益。

一、項(xiàng)目根目錄上建立config.php

代碼如下所示:

<?php
 if(!defined('THINK_PATH')) exit();
 return array(
  'DB_TYPE'    =>  'mysql',// 數(shù)據(jù)庫(kù)類型  
  'DB_HOST'    =>  'localhost',// 主機(jī)
  'DB_NAME'    =>  'aoli',// 數(shù)據(jù)庫(kù)名稱
  'DB_USER'    =>  'root',// 數(shù)據(jù)庫(kù)用戶名
  'DB_PWD'     =>  '',// 數(shù)據(jù)庫(kù)密碼
  'DB_PREFIX'   =>  '',// 數(shù)據(jù)表前綴
  'DB_CHARSET'   =>  'utf8',// 網(wǎng)站編碼
  'DB_PORT'    =>  '3306',// 數(shù)據(jù)庫(kù)端口
 );
?>

二、設(shè)置項(xiàng)目配置文件

\Home\Conf\config.php文件代碼如下:

<?php
 $arr1=array{
  'URL_MODEL'=>2, //pathinfo訪問(wèn)模式
 };
 $arr2=include './config.php';
 return array_merge($arr1,$arr2); //數(shù)組整合
?>

\Admin\Conf\config.php文件代碼如下:

<?php
 $arr1=array{
  'URL_MODEL'=>1, //普通訪問(wèn)模式 get方式
 };
 $arr2=include './config.php';
 return array_merge($arr1,$arr2); //數(shù)組整合
?>

三、主從數(shù)據(jù)庫(kù)設(shè)置

該設(shè)置比較適合高并發(fā),高負(fù)載的大型網(wǎng)站
讀者可以到\ThinkPHP\Common\convention.php中查看默認(rèn)的系統(tǒng)常量設(shè)置

config.php文件設(shè)置如下:

<?php
  return array(
  //'配置項(xiàng)'=>'配置值'
  //后臺(tái)
  'URL_MODE'=>0,
  'DB_TYPE'=>'mysql',
  'DB_HOST'=>'localhost,192.168.1.2',//兩臺(tái)數(shù)據(jù)庫(kù)服務(wù)器
  'DB_PORT'=>'3306',
  'DB_NAME'=>'thinkphptest',//如果數(shù)據(jù)庫(kù)名相同,不用定義多個(gè),如果不相同與服務(wù)器依次對(duì)應(yīng)
  'DB_USER'=>'root',
  'DB_PWD'=>'password',
  //表前綴
  'DB_PREFIX'=>'think_',
  //接下來(lái)配置主從數(shù)據(jù)庫(kù)
  'DB_DEPLOY_TYPE'=>1,//開(kāi)啟分布式數(shù)據(jù)庫(kù)
  'DB_RW_SEPARATE'=>ture,//讀寫(xiě)分離,默認(rèn)第一臺(tái)服務(wù)器為寫(xiě)入服務(wù)器,其它的只讀取不寫(xiě)入
  );
?>

在某個(gè)action中讀取數(shù)據(jù)庫(kù)文件參數(shù):

  $hh=C('DB_HOST'); //C可以讀取配置文件中的值
  $pp=C('DB_PREFIX');
  $this->assain('h',$hh);
  $this->assain('p',$pp);
  $this->display();

這個(gè)action下的tpl:

  數(shù)據(jù)庫(kù)服務(wù)器地址:{$h}
  數(shù)據(jù)庫(kù)表前綴:{$p}

上述就是小編為大家分享的使用ThinkPHP怎么連接數(shù)據(jù)庫(kù)并設(shè)置主從了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI