博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
优秀的PHP开发者是怎样炼成的?
阅读量:5304 次
发布时间:2019-06-14

本文共 1665 字,大约阅读时间需要 5 分钟。

4.在数据库中避免使用联合操作

比起其它的Web编程语言来说,PHP的数据库功能十分强大。但是在PHP中数据库的运行仍然是一件十分费时费力的事情,所以,作为一个Web程序员,要尽量减少数据库的查询操作,同时应该为数据库建立适当的索引。

另一件值得注意的事情是在用PHP操作数据库时,尽可能不使用多个数据表的联合操作,尽管联合操作可以增强数据库的查询功能,但是却大大增加了服务器的负担。为了说明这个问题,我们可以看看下面的这个简单的例子。

我们在数据库中创建了两个数据表foo和big_foo。在数据表foo中,只有一个字段,包含了从1-1000之间的所有自然数。数据表big_foo同样只有一个字段,但包含了从1-1,000,000之间的全部自然数。所以,从大小上说,big_foo等于foo与它自身进行了联合操作。

  1. $db->query(\"select * from foo\");   
  2. 0.032273 secs   
  3. $db->next_record();   
  4. 0.00048999999999999 secs   
  5. $db->query(\"insert into foo values (NULL)\");   
  6. 0.019506 secs   
  7. $db->query(\"select * from foo as a, foo as b\");   
  8. 17.280596 secs   
  9. $db->query(\"select * from foo as a, foo as b where a.id > b.id\");   
  10. 14.645251 secs   
  11. $db->query(\"select * from foo as a, foo as b where a.id = b.id\");   
  12. 0.041269 secs   
  13. $db->query(\"select * from big_foo\");   
  14. 25.393672 secs 

从上面操作结果我们可以发现,对于两个有1000条记录的数据表进行联合,其速度并不比对一个1000000条纪录的大型数据表单独进行操作快多少。

5.注意include与require的区别

在PHP变成中,include()与require()的功能相同,但在用法上却有一些不同,include()是有条件包含函数,而require()则是无条件包含函数。例如在下面的一个例子中,如果变量$somgthing为真,则将包含文件somefile:

  1. if($something){   
  2. include(\"somefile\");   

但不管$something取何值,下面的代码将把文件somefile包含进文件里:

  1. if($something){   
  2. require(\"somefile\");   

下面的这个有趣的例子充分说明了这两个函数之间的不同。

  1. i = 1;   
  2. while ($i < 3) {   
  3. require(\"somefile.$i\");   
  4. $i++;   

在这段代码中,每一次循环的时候,程序都将把同一个文件包含进去。很显然这不是程序员的初衷,从代码中我们可以看出这段代码希望在每次循环时,将不同的文件包含进来。如果要完成这个功能,必须求助函数include();

  1. i = 1;   
  2. while ($i < 3) {   
  3. include(\"somefile.$i\");   
  4. $i++;   

6.注意echo和print的区别

PHP中echo和print的功能也基本相同,但是两者之间也有细微差别。在PHP代码中可以把print作为一个普通函数来使用,例如执行下面的代码后变量$res的值将为1。

  1. $ret = print \"Hello World\";
  2.  

这意味着print可用在一些复杂的表达式中,而echo则不行。同样,在代码中echo语句的运行速度要略微快于print语句,因为echo语句不要求返回任何数值。

转载于:https://www.cnblogs.com/huangye-dream/p/3199897.html

你可能感兴趣的文章
TCP/IP详解学习笔记(3)IP协议ARP协议和RARP协议
查看>>
简单【用户输入验证】
查看>>
python tkinter GUI绘制,以及点击更新显示图片
查看>>
HDU4405--Aeroplane chess(概率dp)
查看>>
CS0103: The name ‘Scripts’ does not exist in the current context解决方法
查看>>
20130330java基础学习笔记-语句_for循环嵌套练习2
查看>>
Spring面试题
查看>>
窥视SP2010--第一章节--SP2010开发者路线图
查看>>
MVC,MVP 和 MVVM 的图示,区别
查看>>
C语言栈的实现
查看>>
代码为什么需要重构
查看>>
TC SRM 593 DIV1 250
查看>>
SRM 628 DIV2
查看>>
2018-2019-2 20165314『网络对抗技术』Exp5:MSF基础应用
查看>>
Python-S9-Day127-Scrapy爬虫框架2
查看>>
SecureCRT的使用方法和技巧(详细使用教程)
查看>>
右侧导航栏(动态添加数据到list)
查看>>
81、iOS本地推送与远程推送详解
查看>>
虚拟DOM
查看>>
自建数据源(RSO2)、及数据源增强
查看>>