ホームページ php教程 php手册 PHPLIB は複数のデータベースにアクセスします

PHPLIB は複数のデータベースにアクセスします

Jun 21, 2016 am 09:07 AM
connect database db this

访问|数据|数据库

【摘 要】 如果你要使用多个数据库的话,它就显得力不从心了,本文介绍了通过扩展PHPLIB,让你鱼和熊掌兼得,在使用PHPLIB的同时可以使用多个数据库,而且从中你也可以了解到面向对象编程和如何扩展库的知识。
  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的使用是完全不同的,并且有不同的运行结果。

扩展PHPLIB

  PHPLIB通过一个DB_Sql类产生的对象来访问数据库。Db_mysql.inc包含了为MySQL修改过的DB_Sql类。我们将通过在common.php中加入代码来扩展DB_sql,这些代码将加在包含db_mysql.inc的行后。

DB_Sql包含了很多用作查询的函数,我们要作修改的是:

<?php

/* public: 连接管理 */
function connect($Database = "", $Host = "", $User = "", $Password = "") {
/* 处理默认连接 */
if ("" == $Database)
$Database = $this->Database;
if ("" == $Host)
$Host = $this->Host;
if ("" == $User)
$User = $this->User;
if ("" == $Password)
$Password = $this->Password;

/* 建立连接,选择数据库 */

if ( 0 == $this->Link_ID ) {
$this->Link_ID=mysql_pconnect($Host, $User, $Password);
if (!$this->Link_ID) {
$this->halt("pconnect($Host, $User, \$Password) failed.");
return 0;
}

if (!@mysql_select_db($Database,$this->Link_ID)) {
$this->halt("cannot use database ".$this->Database);
return 0;
}
}

return $this->Link_ID;
}

?>

  在你的db_mysql.inc(或者其它数据库的相关.inc文件)中找到connect()函数,然后将它拷贝到common.php,放到包含db_mysql.inc代码的后面,在后面,还要将它封装为一个类的定义。

我发现这些代码有些难读,因此,首先令拷贝来的代码的可读性更好:

<?php

/* public: 连接管理*/

function connect($Database = "", $Host = "", $User = "", $Password = "") {
/* 处理默认连接 */
if ("" == $Database) {
$Database = $this->Database;
}
if ("" == $Host) {
$Host = $this->Host;
}
if ("" == $User) {
$User = $this->User;
}
if ("" == $Password) {
$Password = $this->Password;
}
/* 建立连接,选择数据库 */
if ( 0 == $this->Link_ID ) {
$this->Link_ID=mysql_pconnect($Host, $User, $Password);
if (!$this->Link_ID) {
$this->halt("pconnect($Host, $User, \$Password) failed.");
return 0;
}
if (!@mysql_select_db($Database,$this->Link_ID)) {
$this->halt("cannot use database ".$this->Database);
return 0;
}
}
return $this->Link_ID;
}

?>

  我调整了一下括号的位置,并且在单行的前后也加入了一个大括号。在PHP的if语句中,如果只有一句代码的话你可以不用括号,但是,如果你增加多一行代码,就会马上出错。因此我建议你加入一个括号,以免后来加入代码时出错。

  在改变connect的代码之前,先要了解一下connect()是如何工作的,它检查当前是否存在一个连接,如果不存在连接的话,就创建一个连接。在每次的数据库查询之前,首先运行这个connect()函数。可惜的是,它只在首次连接的时候选择数据库,如果你的PHP页面使用超过一个数据库,connect()并不会选择另外的数据库。

  要改变代码的话,有几种不同的方法。我们要选择一种对PHPLIB的影响最小,而且可让我们在需要分析问题的时候,能够显示数据库连接状态的方法。我们需要在PHPLIB外保存连接id和数据库的名字。只要在common.php加入:

<?php

$db_connection = 0; // 数据库连接的id
$db_database = ""; // 当前数据库的状态

?>

  下一步,我们要对PHPLIB作修改,以便在这些变量中存储连接id和数据库的名字。在其它的代码中,你可以设置和使用同样的变量名。在分析问题时,如果你需要知道现在使用哪个数据库,只要在页面中插入以下的代码:

<?php

Print("

db_database: " . $db_database . "

");

?>

我们怎样才能让connect()使用这些新变量呢?我们可以在顶部加入一行:

<?php

{
globals $db_connect, $db_database;
/* Handle defaults */

?>

通过这些代码,新变量就可被connect()访问到

在定义了$db_database后,加入:
<?php

function db_connect($db_connect_host="", $db_connect_user="",$db_connect_pass="") {
globals $db_connect;
if(!empty($db_connect_host)) {
$db_connect = mysql_pconnect($db_connect_host,
$db_connect_user, $db_connect_pass);
}
return($db_connect);
}

function db_database($db_database_new="") {
globals $db_database;
if(!empty($db_database_new)) {
$db_database = @mysql_select_db($db_database_new, db_connect());
}
return($db_database);
}

?>

  只要定义这些公共的函数一次,你就可以在不同的地方使用这些公共的变量,而不需要加入global申明。以下就是使用上面db函数的公共函数:

<?php

function connect($Database = "", $Host = "", $User = "", $Password = "") {
/* 处理默认连接 */
if ("" == $Database) {
$Database = $this->Database;
}
if ("" == $Host) {
$Host = $this->Host;
}
if ("" == $User) {
$User = $this->User;
}
if ("" == $Password) {
$Password = $this->Password;
}
/* 建立连接,选择数据库 */
if ( 0 == db_connect()) {
$this->Link_ID = db_connect($Host, $User, $Password);
if (!$this->Link_ID) {
$this->halt("pconnect($Host, $User, \$Password) failed.");
return 0;
}
}
if (0 != db_connect()) {
if($Database != db_database()) {
$this->Database = db_database($Database))
if(empty($this->Database)) {
$this->halt("cannot use database " . $this->Database);
return 0;
}
}
}
return $this->Link_ID;
}

?>

留意以下改变:

  对数据库的测试从连接的测试中分离出来,这样即使connect()有一个当前连接时,还可以检查是否要换成另外的数据库。这意味着与以前相比,db_connect()和0作比较的次数多了一倍,不过这个额外的处理是必要的。

  我们将数据库连接和数据库选择放在PHPLIB外,这样你就可以在PHP代码的任何地方使用同样的数据库选择函数。

  不过,现在的处理有一个限制,这里我们是假定对于所有的数据库,都使用同样的主机、用户和密码。如果你的数据库对于不同的用户有不同的权限,你必须建立一个特别的连接来访问它。怎样做?只要定义以下变量就可以了:

<?php

$db_host = "";
$db_user = "";
$db_pass = "";

?>

  通过扩展db_database()函数,将当前的用户和主机和某个用户和主机作对比就行。你还可以加入:

<?php

$db_type = "";

?>

  这个变量用来存储数据库的类型,mysql或者Oracle等。这样你就可以访问多个数据库。

  不过要改变代码来处理多个不同类型的数据库是颇复杂的。你必须还要改变查询函数,以及连接和选择函数。你或许可通过PHP的ODBC来连接,然后使用PHPLIB的ODBC选项来处理。ODBC通过一个通用的方式来处理多种数据库,因此将会慢一点。ODBC虽然可让你使用同样的代码来处理多个不同类型的数据库。但是在需要用到不同处理格式的日期时,将会有问题,而且在数据库间也会存在一些奇怪的差异。ODBC只是简化了连接,但是并没有修改数据库解释数据和SQL的方式。

  现在来学习一下如何重新定义一个对象类。connect()函数被封装到一个类的定义中:
<?php

class DB_Sql {

}

?>

我们将该函数拷贝到common.php时,我们必须重新定义DB_Sql类,我们可以这样封装connect():
<?php

class db_DB_Sql extends DB_Sql {

}

?>

  要详细了解"extends"的工作,我们可以看看PHP文档中关于对象和类的部分。简单说来:扩展部分的任何定义替换和覆盖了以前的所有定义。

db_DB_Sql を使用できるようになりました。 PHPLIB を設定するときは、次のステートメントを作成します:

$x = 新しい DB_Sql; > に変更します:

$x = 新しい db_DB_Sql; >

このようにして、前のクラスの代わりに変更されたクラスを使用できます。

データベースへの接続時にエラーが発生した場合、現在の接続状態を外部関数で出力できます。 SQL ステートメントでエラーが発生した場合は、DB_Sql の query() 関数を common.PHP の db_DB_Sql にコピーし、出力ステートメントを挿入して現在の SQL ステートメントを確認することもできます。

エラーまたは診断情報をディスク ファイルに書き込むこともできます。

$db_log_file = "t:/diag.txt";

または同様のテキスト ファイルを定義することによって。 Windows を使用している場合は、ディレクトリが存在することを確認する必要があります。存在しないと、エラー メッセージが表示されます。

次に関数を定義します:

function db_log($db_log_message) { globals $db_log_file;

$db_log_f = fopen($db_log_file, "a");

fwrite($db_log_f, date("Y m d H:i:s"); " ".$db_log_message."rn"); fclose($db_log_f)

? >



情報を記録する必要がある場所に、次のコードを追加します:

db_log("現在のデータベース: " . db_database()); >

実際には、組み込みまたはシステムのログ ファイルを使用できます。ただし、多くのファイルの中から小さな情報を見つけなければなりません。したがって、この別個のログ ファイルはテストに役立ちます。記録の前後に次のコードを書くことをお勧めします:

db_log("現在のデータベース: " . db_database()); db_log("現在のデータベース: " . db_database()); >

データにアクセスするときは、PHPLIB で定義されたデータベースではなく、必ず正しいデータベースを使用してください。データベースのラッパー関数を作成したり、使用する関数を変更したりできます。 mysql_query() を使用する場合は、最初に db_database() を使用し、その後

$result = mysql_db_query(db_database("bookcatalogue"), "select * from?",
db_connect()); > 関数を提案する:

function db_query($db_query_database, $db_query_sql) { return(mysql_db_query(db_database($db_query_database), $db_query_sql, db_connect());

}

の代わりに?


db_database("bookcatalogue");

$result = mysql_query("select * from?",

);

さあ、あなたはそれです実行できます


。 PHPLIB (または同様のソフトウェア) を使用して、複数のデータベースにアクセスします
。 診断チェックを挿入します

この記事を通じて、その方法がわかると思います。 A クラスを拡張するには、いくつかの概念もあります。自分で実践してください

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

discuzデータベースエラーを解決する方法 discuzデータベースエラーを解決する方法 Nov 20, 2023 am 10:10 AM

discuz データベース エラーの解決策は次のとおりです: 1. データベース構成を確認します; 2. データベース サーバーが実行されていることを確認します; 3. データベース テーブルのステータスを確認します; 4. データをバックアップします; 5. キャッシュをクリアします; 6. Discuz を再インストールします; 7. サーバー リソースを確認します。 ; 8. Discuz 公式サポートに連絡します。 Discuz データベース エラーを解決するには、複数の側面から始めて、徐々に問題の原因を調査し、対応する措置を講じて修復する必要があります。

リークにより、Intel Arrow Lake-U、-H、-HX、-S の主要な仕様が明らかに リークにより、Intel Arrow Lake-U、-H、-HX、-S の主要な仕様が明らかに Jun 15, 2024 pm 09:49 PM

IntelArrowLake は、LunarLake と同じプロセッサ アーキテクチャに基づいていると予想されており、つまり、Intel の新しい Lion Cove パフォーマンス コアが経済的な Skymont 効率コアと組み合わされることになります。

Oracle と DB2 の SQL 構文の比較と相違点 Oracle と DB2 の SQL 構文の比較と相違点 Mar 11, 2024 pm 12:09 PM

Oracle と DB2 は一般的に使用される 2 つのリレーショナル データベース管理システムであり、それぞれに独自の SQL 構文と特性があります。この記事では、Oracle と DB2 の SQL 構文を比較し、相違点を示し、具体的なコード例を示します。データベース接続 Oracle では、次のステートメントを使用してデータベースに接続します: CONNECTusername/password@database DB2 では、データベースに接続するステートメントは次のとおりです: CONNECTTOdataba

Oracle と DB2 データベース テクノロジーの比較分析 Oracle と DB2 データベース テクノロジーの比較分析 Mar 11, 2024 am 09:54 AM

Oracle と DB2 は、エンタープライズ アプリケーションで広く使用されている 2 つのよく知られたリレーショナル データベース管理システム (RDBMS) です。この記事では、Oracle と DB2 の 2 つのデータベース テクノロジーを比較し、その特徴、パフォーマンス、機能、使用例の分析を含めて詳しく分析します。 1. Oracle データベース技術の概要 Oracle は、米国 Oracle Corporation が開発したリレーショナル データベース管理システムです。エンタープライズレベルのアプリケーションで広く使用されており、強力なパフォーマンスと安定性を備えています。

Oracle と DB2 データベースのパフォーマンスの比較分析 Oracle と DB2 データベースのパフォーマンスの比較分析 Mar 09, 2024 pm 10:00 PM

Oracle データベースと DB2 データベースは、エンタープライズ レベルのアプリケーションで広く使用されている 2 つの主要なリレーショナル データベース管理システムです。実際のアプリケーションでは、データベースのパフォーマンスがデータベース システムの品質を評価するための重要な指標の 1 つになることがよくあります。この記事では、Oracle データベースと DB2 データベースのパフォーマンスを比較分析し、特定のコード例を使用してそれらの違いを示します。 1. Oracle データベースのパフォーマンス分析 Oracle データベースは、拡張性と安定性に優れた強力なデータベース管理システムです。

db とはどのようなファイル形式ですか? db とはどのようなファイル形式ですか? May 19, 2021 am 11:56 AM

dbとは「datebase」の略で、「データベースファイル」の形式の一つで、ソフトウェアがデータベースに相当するデータを保存するためのファイルで、ソフトウェアごとに保存形式が異なります。たとえば、Win7 システムの「Thumbs.db」はサムネイル データ ファイルであるため、db ファイルは特定のファイル形式ではありません。

dbのファイル形式は何ですか? dbのファイル形式は何ですか? Mar 07, 2023 pm 05:27 PM

db はデータベース ファイル形式で、ソフトウェアがデータを保存するために使用するファイルであり、データベースに相当します。各ソフトウェアには独自の保存形式、つまりデータの配置方法があり、一部のソフトウェア データ ファイルの接尾辞は DB です。たとえば、Win7 システムの Thumbs.db はサムネイル データ ファイルであるため、db ファイルは特定のファイル形式ではありません。

Oracle と DB2 データベース管理システムの機能の比較 Oracle と DB2 データベース管理システムの機能の比較 Mar 11, 2024 am 08:57 AM

Oracle と DB2 は 2 つの一般的なリレーショナル データベース管理システムであり、それぞれに独自の特性と利点があります。この記事では、Oracle と DB2 の特性を比較し、それらの違いを示す具体的なコード例を示します。 1. Oracle データベース管理システムの特徴: ストレージ エンジン: Oracle データベースは、大規模なデータ ストレージを処理できる Oracle Database Engine (OracleDatabaseEngine) と呼ばれる独自のストレージ エンジンを使用します。

See all articles