您现在的位置是: 软件 > 开发者网络 > 程序方舟 > 服务器端脚本编程 > PHP专辑 > 正文


-Win xp中的多种网络
-试验试验试验试验
-用Freehand实现位图矢量化
-网络电话面面观

使用PHPLIB访问多个数据库
2001-03-31· ·QQ新人类··yesky

上一页  1 2 3 4 5 6  下一页


留意以下改变:

  对数据库的测试从连接的测试中分离出来,这样即使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;

?>

这样你就可以使用修改的类,而不是以前的类。

上一页  1 2 3 4 5 6  下一页

■ 相关内容
 INFORMIX5的安装及初始配置
 多php服务器实现多session并发运行
 使用PHP连接LDAP服务器
 建立动态的WML站点
 数据模型:找到最合适的设计
 提升PHP速度全攻略
感谢 访问天极网,如果您觉得该文章涉及版权问题,请看这里!