|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
怎么培养啊 别光说不练啊,好 ,比如新人入门自己步是配置环境,虽然现在都有很多的集成环境,但是真实的体验下配置环境还是会有很多帮助,不论是你以后工作还是在真实的linux下开发。会见|数据|数据库 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;
}
?>
[1] [2] [3] [4] 下一页
刚开始因为习惯于ASP格式的写法,总是在这些方面出现问题,自己还总是找不到问题所在,这就提醒了自己,在写代码的时候一定要认真,不能粗心地老是少个“;”或者字母大小写不分,要不然很可能找半天都找不到错误。 |
|