admin 管理员组

文章数量: 1184232


2024年4月12日发(作者:html5头部标签)

php常见面试题

php常见面试题一

1.用PHP写出显示客户端IP与服务器IP的代码:

echo $_SERVER[REMOTE_ADDR] //客户端ip

echo $_SERVER[SERVER_ADDR] //服务器端ip

2、apache+mysql+php实现最大负载的方法

1) 问的太笼统,生成静态html页面,squid反向代理,apache,mysql的负载

均衡。

2) 可以采取数据缓存的方法,我们通常在统计数据的时候,需要在原始数

据的基础上经过计算等一系列操作,才会得到最终的结果,如果每做一个查询都

需要这样一系列操作,当数据量大时,势必会带来很多问题。可以建立一个结果

表,写一个脚本,用crontab定时触发脚本去原始表取数据,计算,写入到结果

表,前端查询从结果表取数据,这也是比较常用的一种做法。

3) 采用分布式,多个apache,多个mysql,其实就是dns负载均衡,dns

根据当前用户解析几个ip的ping值,将用户转移到某一台最快的服务器,或者

平均分配。

4 )money不是问题的话,可以考虑F5硬件负载均衡!

5)可以使用Microsoft Windows Server系统的负载均衡设置

3.数据库中的事务是什么?

答:事务(transaction)是作为一个单元的一组有序的数据库操作。如果组中

的所有操作都成功,则认为事务成功,即使只有一个操作失败,事务也不成功。

如果所有操作完成,事务则提交,其修改将作用于所有其他数据库进程。如果一

个操作失败,则事务将回滚,该事务所有操作的影响都将取消。

4.1优化MYSQL数据库的方法。

1、选择合适的字段的数据类型

1)能用数字不用字符串

2)char、varchar、text 能用varchar不用char

3)给字段加not null 避免在表中出现NULL关键字(default 值)

2、选择合适的字段充当主键

1)建议每张表必须有主键

2)用数字类型的字段充当主键

3、拆分表

1)拆分字段,将*的标题与内容分开

2)拆分记录,将今年的记录与往年的记录分开

4、给字段合理添加索引

a.格式:

(普通索引)-

创建:CREATE INDEX 索引名 ON tablename (索引字段)

修改:ALTER TABLE tablename ADD INDEX [索引名] (索引字段)

创表指定索引:CREATE TABLE tablename([...],INDEX[索引名](索引字段))

(唯一索引)-

创建:CREATE UNIQUE 索引名 ON tablename (索引字段)

修改:ALTER TABLE tablename ADD UNIQUE [索引名] (索引字段)

创表指定索引:CREATE TABLE tablename([...],UNIQUE[索引名](索引字段))

(主键)-

它是唯一索引,一般在创建表是建立,格式为:

CREATA TABLE tablename ([...],PRIMARY KEY[索引字段])

5、事务处理:

a.保证数据完整性,例如添加和修改同时,两者成立则都执行,一者失败都失

败 mysql_query("BEGIN");

mysql_query("INSERT INTO customerinfo (name) VALUES ($name1)";

mysql_query("SELECT * FROM `orderinfo` where customerid=".$id");

mysql_query("COMMIT");

6、锁定表,优化事务处理:

a.我们用一个 SELECT 语句取出初始数据,通过一些计算,用 UPDATE 语句

将新值更新

php常见面试题二

1、表单提交get和post有何区别?

答:get的方式是把数据在地址栏中发送,get传送的数据量较小,不能大

于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中

最大量为80KB,IIS5中为100KB。

2、用PHP打印出前一天的时间格式是20XX-5-10 22:21:21

echo date("Y-m-d H:i:s",time()-(3600*24));或echo date("Y-m-d

H:i:s",strtotime("-1 day"));

3、php中include和require的区别?

这两种结构除了在如何处理失败之外完全一样。include() 产生一个警告而

require() 则导致一个致命错误。换句话说,如果你想在遇到丢失文件时停止处

理页面就用 require()。include() 就不是这样,脚本会继续运行。

4、echo(),print(),print_r()的区别

echo可以接多个参数,print只能接一个参数,它们都是PHP的语言结

构,print_r是递规打印,用来打印数组或对象

5、能够使HTML和PHP分离开使用的模板

smarty,phplib,SmartTemplate

6、你如何理解MVC模式?

首先说一下框架,框架:就是别人把一些底层,常用操作.比如数据操作(增,

删,改,查)写好.你来直接用.其它的功能要自己来做。

MVC:设计模式,M模型,V显示,C控制.现在许多框架都是基于MVC来做的把

逻辑和显示分开.比如你要换页面,只需要改V里面的东西并不需要再去变动程

序(详细的东西可以上网上!查一下)

7、如何实现PHP、JSP交互?

PHP提供了支持JAVA的类库文件,或者通过HTTP协议来交互数据

8、使用哪些工具进行版本控制?

VSS,CVS,SVN

9、如何实现字符串翻转?

不考虑中英文混合,不是最优算法,不用php库函数翻转字符串:

function str_to_reverse( $str ){

for($length=0;$str[$length]!=null;$length++){;}

$strlength = $length-1;

unset($length);

for($start=0,$end=$strlength;$start$end;$start++,$end--){

$temp = $str[$start];

$str[$start] = $str[$end];

$str[$end] = $temp;

}

unset($temp,$start,$end,$strlength);

return $str;

}

10、优化MYSQL数据库的方法。

1) 将where中用的比较频繁的字段建立索引,联合索引。

2) 保证单表数据不超过200W,适时分割表。

3) 避免使用长连接。


本文标签: 数据 操作 字段 显示 事务