PHPLIB是PHP的一些扩展库,使用它我们可以很方便地对数据库进行各种操作,不过,如果你要使用多个数据库的话......
作者:QQ新人类 来源:yesky 2007年10月27日
关键字: Linux
留意以下改变:
对数据库的测试从连接的测试中分离出来,这样即使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时,你要做以下声明:
<?php
$x = new DB_Sql;
?> Change it to: <?php
$x = new db_DB_Sql;
?>
这样你就可以使用修改的类,而不是以前的类。