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

使用PHPLIB訪問多個數據庫

編輯:PHP綜合

PHPLIB是PHP的一些擴展庫,使用它我們可以很方便地對數據庫進行各種操作,不過,如果你要使用多個數據庫的話,它就顯得力不從心了,本文介紹了通過擴展PHPLIB,讓你魚和熊掌兼得,在使用PHPLIB的同時可以使用多個數據庫,而且從中你也可以了解到面向對象編程和如何擴展庫的知識,值得一讀。

數據庫管理

你可以在一個大型的數據庫中放入任何表。不過時間長了,將會令數據庫變得越來越大,服務器可能會跟不上IO的工作,或者沒有足夠的內存應付所有的訪問? 要分開現有的數據又非常難。明智的辦法是開始時就使用分開的數據庫,並且進行有效的數據庫管理。 如果你有一個賣書的網站,你可能有作者的列表,書價的列表,還有當前的庫存和訂單的列表。當你的業務不斷增長時,訂單將會不斷地增長,而且處理每個訂單都需要進行很多的磁盤訪問。很可能你將在某一天將所有的訂單都放到一個會計系統中。

現在就將訂單放到一個獨立的數據庫吧。由於庫存也是通過訂單更新的,因此庫存量也放到同樣的數據庫中。

作者的列表和書的列表都是一些靜態的信息,要經常讀取,但很少更新。實際上,更新一個作者的記錄可能只需要每5年一次,只在作者寫了一本新書(或者去世)時進行。放這些數據的服務器的配置可與放訂單數據庫的服務器完全不同。

包含PHPLIB

PHPLIB通過一個稱為DB_Sql的類訪問SQL數據庫。根據你需要使用的數據庫類型,將不同的inc文件包含在你的代碼中。在這個例子中,我使用MySQL的版本。

為了在你的代碼中使用DB_Sql,要將PHPLIB文件安裝在它們自己的目錄中。然後,找到你的cgi-bin目錄,並且在cgi-bin的目錄旁創建phplib目錄。下一步,拷貝所有的PHPLIB .inc文件到phplib目錄。最後,修改php.inc文件,只要將“include_path=”的行改為該phplib目錄就可以了。

include_path是PHP使用include()或者require()時查找的目錄,在我的NT workstation中,include的路徑是:

include_path = ".;i:/project52/includes;i:/project52/phplib";

在Linux的系統上

include_path = ".;/home/httpd/includes;/home/httpd/phplib";

在每個PHP頁面的頂部加入

<? php
require(common.php);
? >

common.php3放在includes目錄中,包含了每個頁面要用到的所有數據和函數。在這個例子中的common.php是:

<? php
require(db_mysql.inc);
require(ct_sql.inc);
require(session.inc);
require(auth.inc);
require(perm.inc);
require(user.inc);
require(page.inc);
? >

如果你想知道每個inc文件的用處,可閱讀http://phplib.netuse.de上的PHPLIB文檔。Db_mysql.inc包含了所有DB_SQL類的定義。如果你想使用PostGreSQL代替MySQL,只要用db_pgsql.inc代替db_mysql.inc就可以了。還有10個其它的.inc文件,可以使用MS SQL、Oracle、Sybase或者其它的數據庫。

要注意的是,在這個例子中,require()和include()是完全一樣的。不過,如果放在代碼中,或者在if語句中使用時,Require()和include的使用是完全不同的,並且有不同的運行結果。

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