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) 避免使用长连接。
版权声明:本文标题:php常见面试题 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.roclinux.cn/p/1712928095a612894.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论