您好,欢迎访问三七文档
PHP面试题收集整理(7套带答案)PHPPHP的面试题集收集整理面试题11、用PHP打印出前一天的时间格式是2006-5-1022:21:21date_default_timezone_set(‘Asia/Shanghai’);$times=time()-86400;echodate(‘Y-m-dH:i:s’,$times);2、echo(),print(),print_r()的区别echo只能打印字符串print可以打印字符串和数组中指定的值print_r打印数组中所有的值,不能打印字符串3、能够使HTML和PHP分离开使用的模板4、如何实现PHP、JSP交互?JSP=JavaServerPage5、使用哪些工具进行版本控制?使用过svn6、如何实现字符串翻转?Strrev($str)7、优化MYSQL数据库的方法。根据事务处理机制,采用innDB表或myIsam表。优化sql语句,优化表字段结构。8、谈谈事务处理是指把若干个字操作组成一个完整的操作,保证这个完整的操作要么全部成功,要么全部失败。而不会部分成功,部分失败。一次银行转账有两个操作,从A账户扣钱,给B账户加钱。这是两个自操作,但整个操作必须是一个事务的,以保证不会出错。一般提到事务,多半指数据库事务,在开始一个事务前,调用transbegin,全部搞定后transcommit。当中出问题了自动回滚,也可以需要的时候手动rollback。但基本就是:begin,commit,rollback。9、apache+mysql+php实现最大负载的方法采用缓存机制:静态缓存,memcache等。根据事务处理机制,采用innDB表或myIsam表。优化sql语句,优化表字段结构。10、实现中文字串截取无乱码的方法。从指定位置开始截取1位,判断ass码范围(ord函数),根据不同情况截取1,2,3位长度。存入数组。下一次截取响应往后1,2,3位。依次类推。最后合并数组为字符串,打印字符串。面试题2var$empty=”;var$null=NULL;var$bool=FALSE;var$notSet;var$array=array();1.$a=“hello”;$b=&$a;unset($b);$b=“world”;whatis$a?hellow2.$a=1;$x=&$a;$b=$a++;whatis$b?13.$x=empty($array);whatis$x?trueorfalsetrue4.您是否用过版本控制软件?如果有您用的版本控制软件的名字是?使用过svn5.您是否用过模板引擎?如果有您用的模板引擎的名字是?用过康盛dz的模版机制6.请简单阐述您最得意的开发之作.7.对于大流量的网站,您采用什么样的方法来解决访问量问题?缓存机制8.用PHP写出显示客户端IP与服务器IP的代码:echo$_SERVER['SERVER_ADDR'];echo$_SERVER['REMOTE_ADDR'];面试题3一、PHP/MySQL编程1)某内容管理系统中,表message有如下字段id文章idtitle文章标题content文章内容category_id文章分类idhits点击量创建上表,写出MySQL语句createtablemessage(idint(32)primarykeyautoincrement,titlevarchar(255),contenttext,category_idtinyint(1),hitssmallint(8))2)同样上述内容管理系统:表comment记录用户回复内容,字段如下comment_id回复idid文章id,关联message表中的idcomment_content回复内容现通过查询数据库需要得到以下格式的文章标题列表,并按照回复数量排序,回复最高的排在最前面文章id文章标题点击量回复数量用一个SQL语句完成上述查询,如果文章没有回复则回复数量显示为0selectmessage.id,message.hits,comment.countSELECTt.id,t.title,t.hits,COUNT(c.comment_id)FROMmessagetLEFTJOINCOMMENTcONt.id=c.idGROUPBYt.id,t.title,t.hitsORDERBYCOUNT(c.comment_id)LIMIT0,303)上述内容管理系统,表category保存分类信息,字段如下category_idint(4)notnullauto_increment;categroy_namevarchar(40)notnull;用户输入文章时,通过选择下拉菜单选定文章分类写出如何实现这个下拉菜单$link=mysql_connect(……);Mysql_select_db(….,$link);$sql=‘selectcategory_id,categroy_namefromcategory’;$result=mysql_query($sql,$link);Echo“selectname=’st’”;While($row=mysql_fetch_array($result)){Echo“optionvalue=’”.$row['category_id'].”‘”.$row['categroy_name'].”/option”}Echo“/select”;二、PHP文件操作1)上述内容管理系统:用户提交内容后,系统生成静态HTML页面;写出实现的基本思路将用户提交的内容写入数据库。再从数据库取出这些数据,生成缓存字符串cache,加载模版html静态页面,解析缓存cache,将数据导入静态页面。保存为缓存文件,存放入指定目录。2)简单描述用户修改以发布内容的实现流程和基本思路从数据库读取信息,显示在修改页面。用户修改,最后提交。写入数据库。更新缓存文件。三、PHP程序1)写出以下程序的输出结果$b=201;$c=40;$a=$b$c?4:5;echo$a;4?2)写出以下程序的输出结果$str=”cd”;$$str=”hotdog”;$$str.=”ok”;这里有点!!echo$cd;hotdogok?面试题4一.简答题1.请说明php中传值与传引用的区别。什么时候传值什么时候传引用?传值只是把某一个变量的值传给了另一个变量,而引用则说明两者指向了同一个地方。2.在PHP中error_reporting这个函数有什么作用?error_reporting()用于指定PHP程序过程中的错误报告的严重程度,有很多种3.请写一个函数验证电子邮件的格式是否正确functionCheckMailAdr($str){//电子邮件验证函数return(eregi(“^[_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,3}$”,$str));}4.简述如何得到当前执行脚本路径,包括所得到参数。说明:例如有一个脚本传给他的参数有参数1,参数2,参数3….传递参数的方法有可能是GET有可能是POST,那么现在请写出类似参数1=值1&参数2=值2…..的结果5.如何修改SESSION的生存时间.去php.ini里修改session.gc_maxlifetime6..有一个网页地址如何得到它的内容?$files=file_get_contents();7.有一个一维数组,里面存储整形数据,请写一个函数,将他们按从大到小的顺序排列。要求执行效率高。并说明如何改善执行效率。(该函数必须自己实现,不能使用php函数)functionBubbleSort($str){for($i=0;$icount($str);$i++){for($j=count($str)-2;$j=$i;$j–){if($str[$j+1]$str[$j]){$tmp=$str[$j+1];$str[$j+1]=$str[$j];$str[$j]=$tmp;}}}return$str;}8.请举例说明在你的开发过程中用什么方法来加快页面的加载速度。生成静态HTML。生成XML。使用缓存,可不用数据库的尽量不用数据库,把变量参数存于文本。二.数据库设计题:请设计一套图书馆借书管理系统的数据库表结构;可以记录基本的用户信息、图书信息、借还书信息;数据表的个数不超过6个;请画表格描述表结构(需要说明每个字段的字段名、字段类型、字段含义描述);在数据库设计中应:1.保证每个用户的唯一性;2.保证每种图书的唯一性;每种图书对应不等本数的多本图书;保证每本图书的唯一性;3.借书信息表中,应同时考虑借书行为与还书行为,考虑借书期限;4.保证借书信息表与用户表、图书信息表之间的参照完整性;5.限制每个用户最大可借书的本数6.若有新用户注册或新书入库,保证自动生成其唯一性标识7.为以下的一系列报表需求提供支持:(无特定说明,不需编写实现语句,而需在数据库设计中,保证这些报表可以用最多一条SQL语句实现)a)日统计报表:当日借书本数、当日还书本数报表;b)实时报表:i.当前每种书的借出本数、可借本数;ii.当前系统中所有超期图书、用户的列表及其超期天数iii.当前系统中所有用户借书的本数,分用户列出(包括没有借书行为的用户);请编写实现此需求的SQL语句:数据库应用:请撰写一系列的SQL语句,分别描述完整的借书行为与还书行为;并保证这一系列的SQL语句的执行完整性下题是测验能力之最重要测试,如不能完成我们将无法给出评判结果!所以请写出详细的回答,并保证答案是可以执行的程序。在两日内将结果通过电子邮件寄到hr@88keke.com邮箱结合第二题中你的设计,用一种数据库实现,要求使用三层结构或者多层结构,要求采用面向对象的思想进行编程,有可能的话,设计一套模板机制来实现之。功能:列出当前借出图书的情况,按日期排列编号用户姓名书名书的编号借出日期1.张进大染坊125765872004-9-12.刘兴西游记321310982004-9-2……面试题51.在PHP中,当前脚本的名称(不包括路径和查询字符串)记录在预定义变量(1)中;而链接到当前页面的URL记录在预定义变量(2)中。2.执行程序段将输出(3)。3.在HTTP1.0中,状态码401的含义是(4);如果返回”找不到文件”的提示,则可用header函数,其语句为(5)。4.数组函数arsort的作用是(6);语句error_reporting(2047)的作用是(7)。5.PEAR中的数据库连接字符串格式是(8)。6.写出一个正则表达式,过虑网页上的所有JS/VBS脚本(即把script标记及其内容都去掉):(9)。7.以Apache模块的方式安装PHP,在文件http.conf中首先要用语句(10)动态装载PHP模块,然后再用语句(11)使得Apache把所有扩展名为php的文件都作为PHP脚本处理。8.语句include和require都能把另外一个文件包含到当前文件中,它们的区别是(12);为了避免多次包含同一文件,可以用语句(13)来代替它们。9.类的属性可以序列化后保存到session中,从而以后可以恢复整个类,这要用到的函数是(14)。10.一个函数的参数不能是对变量的引用,除非在php.ini中把(15)设为on.11.SQL中LEFTJOIN的含义是(16)。如果tbl_user记录了学生的姓名(name)和学号(ID),tbl_score记录了学生(有的学生考试以后被开除了,没有其记录)的学号(ID)和考试成绩(score)以及考试科目(subject),要想打印出各个学生姓名及对应的的各科总成绩,则可以用SQL语句(17)。12.在PHP中,heredoc是一种特殊的字
本文标题:PHP笔试题目
链接地址:https://www.777doc.com/doc-2850451 .html