PHP筆試題含答案

才智咖 人氣:7.54K

1、用PHP打印出前一天的時間,格式是2006-5-10 22:21:21

PHP筆試題含答案

//echo date('Y-m-d H:i:s',time()-60*60*24

echo date("Y:m:d H:i:s",strtotime("-1 day"));

?>

2、echo(),print(),print_r()的區別

echo是語言結構,無返回值;print功能和echo基本相同,不同的是print是函式,有返回值;print_r是遞迴列印,用於輸出陣列物件

3、能夠使HTML和PHP分離開使用的模板

so much,其實PHP本身就是一種模版引擎,我用過的是smarty,常見的還有PHPLib,FastTemplate,Savant這裡有個模板引擎列表:

4.如何實現PHP、JSP互動?

題目有點含糊不清,SOAP,XML_RPC,Socket function,CURL都可以實現這些,如果是考PHP和Java的整合,PHP內建了這種機制(如果考PHP和的整合,也可以這麼回答), 例如$foo = new Java(‘em’);

5.使用哪些工具進行版本控制?

CVS和SVN,SVN號稱下一代CVS,功能強大,不過CVS是老牌,市佔率很高.我一直用SVN,題目是問用什麼工具,呃,這個可能需要這麼回答:CVS Server on Apache作服務端,WinCVS作客戶端;Subversion on Apache/DAV 做服務端,TortoiseSVN做客戶端,或者Subclipse做客戶端

6.如何實現字串翻轉?

其實PHP本身就有字串翻轉的函式:strrev(),不妨試試echo strrev($str);不過所有的這三種方法都不能解決中文字串翻轉的問題,會出錯的。

function reverse($var)

{

$res="";

for($i=0,$j=strlen($var);$i<$j;$i++)

{

$res=$var[$i].$res;

}

return $res;

}

$tmpvar="wofang";

$res=reverse($tmpvar);

echo $res;

?>

7、優化MYSQL資料庫的方法。

(1).資料庫設計方面,這是DBA和Architect的責任,設計結構良好的資料庫,必要的時候,去正規化(英文是這個:denormalize,中文翻譯成啥我不知道),允許部分資料冗餘,避免JOIN操作,以提高查詢效率

(2).系統架構設計方面,表雜湊,把海量資料雜湊到幾個不同的表裡面.快慢表,快表只留最新資料,慢表是歷史存檔.叢集,主伺服器Read & write,從伺服器read only,或者N臺伺服器,各機器互為Master

(3).(1)和(2)超越PHP Programmer的要求了,會更好,不會沒關係.檢查有沒有少加索引

(4).寫高效的SQL語句,看看有沒有寫低效的SQL語句,比如生成笛卡爾積的全連線啊,大量的Group By和order by,沒有limit等等.必要的'時候,把資料庫邏輯封裝到DBMS端的儲存過程裡面.快取查詢結果,explain每一個sql語句

(5).所得皆必須,只從資料庫取必需的資料,比如查詢某篇文章的評論數,select count(*) … where article_id = ? 就可以了,不要先select * … where article_id = ?然後msql_num_rows.

只傳送必須的SQL語句,比如修改文章的時候,如果使用者只修改了標題,那就update … set title = ? where article_id = ?不要set content = ?(大文字)

(6).必要的時候用不同的儲存引擎.比如InnoDB可以減少死鎖可以提高一個數量級的查詢速度

8、談談事務處理

A給B的賬戶轉賬50美元的例子