当前位置: 首页 > 图文教程 > 网络编程 > PHP > 用DBSQL类加快开发MySQL数据库程序的速度

PHP
用PHP实现Ftp用户的在线管理
用PHP实现分段下载
最令PHP初学者头痛的十四个问题
用PHP写的MD5加密函数
PHP应用程序加速探索之简介
将SSH与PHP相连接 确保传输数据的安全
PHP制作的仿百度的站内搜索引擎代码
PHP读取汉字点阵数据
PHP实现任意字符集下正常显示网页的方法
利用PHP的OOP特性实现数据保护
关于PHP字符集的问题
新手入门:IIS6环境下的PHP最佳配置方法
新手入门:初学动态网页PHP的18个例子
基于PHP的AJAX技术实现文件异步上传
PHP技巧--通过COM使用ADODB
PHP技巧:正确理解PHP程序编译时的错误信息
PHP技巧:分析利用PHP制作新闻系统的步骤
PHP技巧:通过实例深入剖析require和include的用法
PHP技巧:优化动态网页技术PHP程序的12条技巧
PHP技巧:使用APC缓存优化PHP程序

PHP 中的 用DBSQL类加快开发MySQL数据库程序的速度


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 81 ::
收藏到网摘: n/a

当你在编写存取MYSQL的数据库程序时,是不是觉得很麻烦:一大套的函数和参数,还要检查调用的结果,更头痛的是每个程序里都要包含数据库名、用户、密码等,想修改都不容易。但如果你使用PHPLIB里的DBSQL类,这些问题都会迎刃而解的。这篇文章将教你如何使用DBSQL类。 


一、获得DBSQL 

怎么获得DBSQL呢,有两个办法: 
- 由于DBSQL是PHPLIB的一部分,你可以从本站或http://phplib.netuse.de下载一份PHPLIB 
- 直接从本站下载DBSQL类,我已经把它独立了,并做了一些小的修改。下载地址:http://www.phpuser.com/programs_and_code/codedetail.php?id=3 

二、修改DBSQL文件。 
打开文件,找到大约138行处,把$Host, $Database, $User, $Password等四个变量改成你机器上的值。 

三、使用DBSQL 

就这么简单,可以派上用场了了,下面是一个典型的例子(这里我们假设DBSQL类存放在db.php文件里): 
<? 
01 require "db.php"; 
02 $db=new DBSQL; 
03 $db->connect(); 
04 if ($db->Link_ID) 

05 $db->query("SELECT id, name FROM contact WHERE id > 100 AND id 
< 200"); 
06 if ($db->nf()) 

07 while ($db->next_record()) 

08 echo "id=", $db->f("id"); 
09 echo "<br>"; 
10 echo "name"; 
11 $db->p('name'); 
12 echo "<br>"; 


13 $db->free_result(); 

?> 
我来逐行解释一下: 
01-将db.php文件包含进来 
02-创建一个DBSQL类的实例,变量名为:$db 
03-调用DBSQL的connect()方法,连接数据库。这行的作用跟mysql_pconnect(host, 
db, passwd)一样 
04-通过检查$db的属性Link_ID的值来判断连接是否成功。一般来说只要配置没问题,这步可以省略的 
05-如果连接没问题,就调用DBSQL类的query方法来执行查询 
06-DBSQL类的nf()函数返回查询后返回的记录的条数,跟mysql_num_rows()的作用一样。如果找到了记录,继续执行 
07-用一个while循环,以DBSQL的next_record()方法为条件。next_record()方法把DBSQL类的结果的指针往下移一条,如果到了结尾,就返回假值 
08-用DBSQL类的f()方法取回查询结果当前一行的某个字段的值。该方法的参数是字段的名字,如$db->f("id") 
11-用DBSQL类的p()方法。p()方法与f()方法不同的是它把查询结果当前一行的某个字段的值直接输出了。该方法的参数是与f()方法一样也是字段的名字,如$db->p("id") 
13-释放PHP占用的内存。相当于调用了mysql_free_result函数 

DBSQL的基本用法就是这样,当然还有其他一些,我在下面来介绍。 

四、其他内容 

Auto_free属性:如果设为真值,当调用next_record()方法到达查询结果的结尾时,DBSQL自动执行free_result()方法,释放占用的内存  DebugMode属性:如果设为真值,在执行query()方法时,会把查询的SQL语句打印出来,所以在做调试时特别有用 

seek()方法:移动DBSQL查询结果的指针,第一个为0 
num_rows()方法:跟nf()方法一样,返回查询结果的记录条数 
metadata()方法:以表名为参数,返回一个包括该表的结果的数组