程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP訪問數據庫集群的方法小結

PHP訪問數據庫集群的方法小結

編輯:PHP綜合

本文總結分析了PHP訪問數據庫集群的方法。分享給大家供大家參考,具體如下:

一般常見的有三種做法:

1、自動判斷sql是否為讀,來選擇數據庫的連接:

實例化php DB類的時候,需要一次連接兩台服務器,然後根據slq選擇不同的連接,舉個例子:

$link_w = mysql_connect($w_host,$user,$pwd);
$link_r = mysql_connect($r_host,$user,$pwd);
//執行sql
if(preg_match("/^select/i", trim($sql))) {
  mysql_query($sql,$link_r);
}else {
  mysql_query($sql,$link_w);
}

這個方法的優點就是開發者執行sql不用區分讀或者寫,在db類的底層自己判斷,缺點是,往往只需要讀或者寫時也需要打開兩個連接。

2、調用的時候自己選擇:

當執行sql前一般是能確定是寫還是讀,所以開發者需要手動的調用不同的連接,舉個例子:

$w_db = new DB('w');
$w_db -> query('insert into .....');

當sql為讀:

$r_db = new DB('r');
$r_db -> query('select .....');

主要通過,傳的參數來區別sql是讀還是寫,每次調用sql前需要調用開發者自己判斷。

3、使用MySQL Proxy做中間層代理,會自動將判斷sql是讀或者寫,將請求轉發給服務器。優點是程序不用更改任何代碼,只要啟動mysql proxy 時分別指定讀或寫的服務器:

--proxy-backend-addresses
--proxy-read-only-backend-addresses

更多關於PHP相關內容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(包括word,excel,access,ppt)》、《php日期與時間用法總結》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved