php通用数据库类 php数据库类库( 三 )


从运行的结果我们可以看出使用str_replace替代ereg_replace作为字符串替换函数 极大地提高了代码的运行速度
注意字符串的引用
PHP 和其它很多编程语言一样 可以使用双引号( )来引用字符串 也可以使用单引号() 但是在PHP中 如果使用双引号来引用字符串 那么PHP解析器将首先分析字符串中有没有对变量的引用 有变量的话 将对变量进行替换 如果是单引号 则没有如此复杂——直接将单引号包含起来的所有字符串直接显示出来 显然 在PHP编程中 如果使用单引号引用字符串变量要比使用双引号快速一些
在数据库中避免使用联合操作
比起其它的Web编程语言来说 PHP的数据库功能十分强大 但是在PHP中数据库的运行仍然是一件十分费时费力的事情 所以 作为一个Web程序员 要尽量减少数据库的查询操作 同时应该为数据库建立适当的索引 另一件值得注意的事情是在用PHP操作数据库时 尽可能不使用多个数据表的联合操作 尽管联合操作可以增强数据库的查询功能 但是却大大增加了服务器的负担
为了说明这个问题 我们可以看看下面的这个简单的例子
我们在数据库中创建了两个数据表foo和big_foo 在数据表foo中 只有一个字段 包含了从 - 之间的所有自然数 数据表big_foo同样只有一个字段 但包含了从 - 之间的全部自然数 所以 从大小上说 big_foo等于foo与它自身进行了联合操作
$db-query( select * from foo ); secs $db-next_record(); secs $db-query( insert into foo values (NULL) ); secs $db-query( select * from foo as a foo as b ); secs $db-query( select * from foo as a foo as b where a idb id ); secs $db-query( select * from foo as a foo as b where a id = b id ); secs $db-query( select * from big_foo ); secs
从上面操作结果我们可以发现 对于两个有 条记录的数据表进行联合 其速度并不比对一个 条纪录的大型数据表单独进行操作快多少
注意include与require的区别
在PHP变成中 include()与require()的功能相同 但在用法上却有一些不同 include()是有条件包含函数 而require()则是无条件包含函数 例如在下面的一个例子中 如果变量$somgthing为真 则将包含文件somefile
if($something){include( somefile ); }
但不管$something取何值 下面的代码将把文件somefile包含进文件里
if($something){require( somefile ); }
下面的这个有趣的例子充分说明了这两个函数之间的不同
$i = ; while ($i) {require( somefile $i );$i++; }
在这段代码中 每一次循环的时候 程序都将把同一个文件包含进去 很显然这不是程序员的初衷 从代码中我们可以看出这段代码希望在每次循环时 将不同的文件包含进来 如果要完成这个功能 必须求助函数include()
$i = ; while ($i) { include( somefile $i ); $i++; }
注意echo和print的区别
PHP中echo和print的功能也基本相同 但是两者之间也有细微差别 在PHP代码中可以把print作为一个普通函数来使用 例如执行下面的代码后变量$res的值将为 $ret = print Hello World ;
lishixinzhi/Article/program/PHP/201405/30767
最好用的PHP数据库操作类-ezSQL ezSQL是一个非常好用的PHP数据库操作类 著名的开源博客WordPress的数据库操作就使用了ezSQL的MySQL部分 该数据库操作类支持几乎所有主流的数据库 如 PHP PDO mySQL Oracle InterBase/FireBird PostgreSQL SQLite以及MS SQL等 ezSQL具有很强的调试功能 可以快速地查看SQL代码的执行情况 使用ezSQL 可以为我们节省开发时间 简化代码并提高运行效率
ezSQL的优点就不用多说了 它小巧 快速 简单 易用 并且开源 还有就是安全 你没想到的细节它都为你考虑了 你只需要在你的脚本开头包含相关的PHP文件 然后你就可以使用更好用的一套ezSQL函数来代替标准的PHP数据库操作函数

推荐阅读