久久99精品久久久久久琪琪,久久人人爽人人爽人人片亞洲,熟妇人妻无码中文字幕,亚洲精品无码久久久久久久

php程序員面試題(b卷_附答案)

時間:2019-05-12 21:41:50下載本文作者:會員上傳
簡介:寫寫幫文庫小編為你整理了多篇相關的《php程序員面試題(b卷_附答案)》,但愿對你工作學習有幫助,當然你在寫寫幫文庫還可以找到更多《php程序員面試題(b卷_附答案)》。

第一篇:php程序員面試題(b卷_附答案)

1.以下哪一句不會把 John 新增到 users 陣列?

$users[] = 'john';成功把 John 新增到陣列 users。

array_add($users,?john?);函式 array_add()無定義。

array_push($users,?john?);

成功把 John 新增到陣列 users。

$users ||= 'john';語法錯誤。

2.sort()、assort()、和 ksort()有什么分別?它們分別在什么情況下使用? sort()根據陣列中元素的值,以英文字母順序排序,索引鍵會由 0 到 n-1 重新編號。主要是當陣列索引鍵的值無關疼癢時用來把陣列排序。

assort()PHP 沒有 assort()函式,所以可能是 asort()的筆誤。asort()與 sort()一樣把陣列的元素按英文字母順序來排列,不同的是所有索引鍵都獲得保留,特別適合替聯想陣列排序。

ksort()根據陣列中索引鍵的值,以英文字母順序排序,特別適合用于希望把索引鍵排序的聯想陣列。3.以下的代碼會產生什么?為什么? $num =10;function multiply(){ $num =$num *10;}

multiply();echo $num;由于函式 multiply()沒有指定 $num 為全域變量(例如 global $num 或者 $_GLOBALS['num']),所以 $num 的值是 10。

4.reference 跟一個正規的變量有什么分別?如何 pass by reference?在什么情況下我們需要這樣做?

Reference 傳送的是變量的地址而非它的值,所以在函式中改變一個變量的值時,整個應用都見到這個變量的新值。

一個正規變量傳送給函式的是它的值,當函式改變這個變量的值時,只有這個函式才見到新值,應用的其他部分仍然見到舊值。

$myVariable = “its' value”;Myfunction(&$myVariable);// 以 reference 傳送參數以 reference 傳送參數給函式,可以使函式改變了的變量,即使在函式結束后仍然保留新值。5.些函式可以用來在現正執行的腳本中插入函式庫?

對這道題目不同的理解會有不同的答案,我的第一個想法是插入 PHP 函式庫不外乎 include()、include_once()、require()、require_once(),但細心再想,“函式庫”也應該包括 com 物件和.net 函式庫,所以我們的答案也要分別包括 com_load 和 dotnet_load,下次有人提起“函式庫”的時候,別忘記這兩個函式。6.foo()與 @foo()有什么分別?

foo()會執行這個函式,任何解譯錯誤、語法錯誤、執行錯誤都會在頁面上顯示出來。@foo()在執行這個函式時,會隱藏所有上述的錯誤訊息。

很多應用程式都使用 @mysql_connect()和 @mysql_query 來隱藏 mysql 的錯誤訊息,我認為這是很嚴重的失誤,因為錯誤不該被隱藏,你必須妥善處理它們,可能的話解決它們。7.你如何替 PHP 的應用程式偵錯?

我并不常這樣做,我曾經試過很多不同的偵錯工具,在 Linux 系統中設定這些工具一點也不容易。不過以下我會介紹一個近來頗受注目的偵錯工具。

PHPAPD,第一步是執行以下的指令安裝: pear install apd安裝后在你的腳本的開頭位置加入以下的語句開始進行偵錯: apd_set_pprof_trace();執行完畢,打開以下檔案來查閱執行日志: apd.dumpdir 你也可以使用 pprofp 來格式化日志。

詳細的資料可以參閱 http://us.php.net/manual/en/ref.apd.php。8.“===”是什么?試舉一個“==”是真但“===”是假的例子。“===”是給既可以送回布爾值“假”,也可以送回一個不是布爾值但卻可以賦與“假”值的函式,strpos()和 strrpos()便是其中兩個例子。

問題的第二部份有點困難,想一個“==”是假,但是“===”是真的例子卻很容易,相反的例子卻很少。但我終于找到以下的例子:

if(strpos(“abc”, “a”)== true){ // 這部分永不會被執行,因為 “a” 的位置是 0,換算成布爾值“假”}if(strpos(“abc”, “a”)=== true){ // 這部份會被執行,因為“===”保證函式 strpos()的送回值不會換算成布爾值.}

9.你會如何定義一個沒有成員函式或特性的類別 myclass? class myclass{}

10.你如何產生一個 myclass 的物件? $obj = new myclass();

11.在一個類別內如何存取這個類別的特性及變改它的值? 使用語句:$this->propertyName,例如:

class myclass{ private $propertyName;public function __construct(){ $this->propertyName = “value”;}}

12.include 和 include_once 有什么分別?require 又如何?

三者都是用來在腳本中插入其他檔案,視乎 url_allow_fopen 是否核準,這個檔案可以從系統內部或外部取得。但他們之間也有微細的分別:

include():這個函式容許你在腳本中把同一個檔案插入多次,若果檔案不存在,它會發出系統警告并繼續執行腳本。

include_once():它跟 include()的功能相似,正如它的名字所示,在腳本的執行期間,有關檔案只會被插入一次。

require():跟 include()差不多,它也是用來在腳本中插入其他檔案,但若果檔案不存在,它會發出系統警告,這個警告會引致致命錯誤令腳本中止執行 13.以下哪一個函式可以把瀏覽器轉向到另一個頁面? redir()

這不是一個 PHP 函式,會引致執行錯誤。header()這個是正確答案,header()用來插入卷頭資料,可以用來使瀏覽器轉向到另一個頁面,例如: header(“Location: http:// 標簽除去? 首先,PHP 有內建函式 strip_tags()除去 HTML 標簽,為何要自行編寫正規表達式?好了,便當作是面試的一道考題吧,我會這樣回答:

$stringOfText = ”

This is a test

“;$expression = ”/<(.*?)>(.*?)/“;echo preg_replace($expression, ”[url=file://2/]2[/url]“, $stringOfText);// 有人說也可以使用 /(<[^>]*>)/ $expression = ”/(<[^>]*>)/“;echo preg_replace($expression, ”“, $stringOfText);18.PHP 和 Perl 分辨陣列和散列表的方法有什么差異? 這正是為何我老是告訴別人選擇適當的編程語言,若果你只用一種語言的話你怎么能回答這道問題?這道問題很簡單,Perl 所有陣列變量都是以 @ 開頭,例如 @myArray,PHP 則沿用 $ 作為所有變量的開頭,例如 $myArray。

至于 Perl 表示散列表則用 %,例如 %myHash,PHP 則沒有分別,仍是使用 $,例如 $myHash。

19.你如何利用 PHP 解決 HTTP 的無狀態本質?

最主要的倆各選擇是 session 和 cookie。使用 session 的方法是在每一頁的開始加上 session_start(),然后利用 $_SESSION 散列表來儲存 session 變量。至于 cookie 你只需記著一個原則:在輸出任何文字之前調用 set_cookie()函式,此外只需使用 $_COOKIE 散列表便可以存取所有 cookie 變量。

還有一個不那么可靠的方法,就是利用訪客的 IP 地址,這個方法有特定的危險性。20.GD 函式庫用來做什么?

這個可能是我最喜歡的函式庫,自從 PHP 4.3.0 版本后 GD 便內建在 PHP 系統中。這個函式庫讓你處理和顯示各式格式的圖檔,它的另一個常見用途是制作所圖檔。GD 以外的另一個選擇是 ImageMagick,但這個函式庫并不內建于 PHP 之中,必須由系統管理員安裝在伺服器上。

21.試寫出幾個輸出一段 HTML 代碼的方法。

嗯,你可以使用 PHP 中任何一種輸出語句,包括 echo、print、printf,大部分人都使用如下例的 echo:

echo ”My string $variable";你也可以使用這種方法:

echo << HTML tags in here as well. The END;remarks must be on a line of its own, and can't contain any extra white space.END;22.PHP 比 Perl 好嗎?請討論。

我們不要為一個簡單的問題引發一場舌戰,正如我經常說的:“為工作選擇適合的語言,不要把工作遷就語言。”我個人認為 Perl 十分適合用作命令行工具,雖然它在網頁應用上也有不錯的表現,但是它的真正實力在命令行上才能充分發揮。同樣地,PHP 雖然可以在控制臺的環境中使用,但是個人認為它在網頁應用上有更好的表現,PHP 有大量專門為網頁應用而設計的函式,Perl 則似乎以命令行為設計之本。

個人來說兩種語言我都喜歡,在大學期間我經常使用 Perl、PHP 和 Java,可惜工作上我使用 C#,但在家里我花不少時間操練 PHP、Perl、Ruby(現正學習)和 Java,保持我的技能知識在最新狀態。很多人問我 C 和 C++ 怎么樣,它們是否仍有機會在我的應用中占一席位,我的答案基本上是“否”,我近來的工作主要集中在網頁開發,雖然 C 和 C++ 也可以用來寫網頁,但它們到底不是為這種工作而設計的,“為工作選擇適合的語言”,若果我需要編寫一個控制臺應用,用來展示 bubble sort、quick sort 和 merge sort 的效能比較,我一定會使用 C / C++。若果我需要編寫一個相片簿系統,我會使用 PHP 或者 C#(我認為制作用戶介面方面.NET 語言比網頁更加)。

第二篇:php程序員面試題(a卷 附答案)

1.在PHP中,當前腳本的名稱(不包括路徑和查詢字符串)記錄在預定義變量(1)中;而鏈接到當前頁面的的前一頁面URL記錄在預定義變量(2)中

//本頁地址,SCRIPT_NAME也可以:php/test.php

echo $_SERVER['PHP_SELF'].“
”;

//鏈接到當前頁面的前一頁面的 URL 地址:

echo $_SERVER['HTTP_REFERER'].“
”;

//其它的見參考手冊:語言參考》變量》預定義變量

//前執行腳本的絕對路徑名:D:Inetpubwwwrootphp est.php

echo $_SERVER[“SCRIPT_FILENAME”].“
”;

//正在瀏覽當前頁面用戶的 IP 地址:127.0.0.1

echo $_SERVER[“REMOTE_ADDR”].“
”;

//查詢(query)的字符串(URL 中第一個問號 ? 之后的內容):id=1&bi=2

echo $_SERVER[“QUERY_STRING”].“
”;

//當前運行腳本所在的文檔根目錄:d:inetpubwwwroot

echo $_SERVER[“DOCUMENT_ROOT”].“
”;

?>

2.執行程序段將輸出__。

//參考手冊》語言參考》運算符》算術運算符》%為取模運算,輸出0

echo 8%(-2).“
”;

//取模 $a % $b 在 $a 為負值時的結果也是負值。輸出-2

echo((-8)%3).“
”;

//輸出2

echo(8%(-3)).“
”;

?>

3.在HTTP 1.0中,狀態碼 401 的含義是____;如果返回“找不到文件”的提示,則可用 header 函數,其語句為____。

答:401表示未授權;header(“HTTP/1.0 404 Not Found”);[見參考手冊》函數參考》HTTP函數》header]

4.數組函數 arsort 的作用是____;語句 error_reporting(2047)的作用是____。

答:arsort:對數組進行逆向排序并保持索引關系 error_reporting(2047)的作用是:report All errors and warnings

5.寫出一個正則表達式,過慮網頁上的所有JS/VBS腳本(即把script標記及其內容都去掉):

$script=“以下內容不顯示:”;echo preg_replace(“/].*?>.*?/si”, “替換內容”, $script);?>

6.以Apache模塊的方式安裝PHP,在文件http.conf中首先要用語句____動態裝載PHP模塊,然后再用語句____使得Apache把所有擴展名為php的文件都作為PHP腳本處理。答:LoadModule php5_module “c:/php/php5apache2.dll”;AddType

application/x-httpd-php.php

見參考手冊》目錄》II.安裝與配置》6.Windows 系統下的安裝》Microsoft Windows 下的 Apache 2.0.x

7.語句 include 和 require 都能把另外一個文件包含到當前文件中,它們的區別是____;為了避免多次包含同一文件,可以用語句____來代替它們。

答:在如何處理失敗時,include()產生一個警告而 require()則導致一個致命錯誤;require_once()/include_once()

8.一個函數的參數不能是對變量的引用,除非在php.ini中把____設為on.答:allow_call_time_pass_reference boolean :是否啟用在函數調用時強制參數被按照引用傳遞, 見參考手冊》附錄G

9.SQL 中LEFT JOIN的含義是__,如果 tbl_user記錄了學生的姓名(name)和學號(ID),tbl_score記錄了學生(有的學生考試以后被開除了,沒有其記錄)的學號(ID)和考試成績(score)以及考試科目(subject),要想打印出各個學生姓名及對應的的各科總成績,則可以用SQL語句____.答:自然左外連接

create database phpinterview;

use phpinterview

create table tbl_user

(IDintnot null,namevarchar(50)not null,primary key(ID));

create table tbl_score

(IDintnot null,scoredec(6,2)not null,subjectvarchar(20)not null);

insert into tbl_user(ID, name)values(1, 'beimu');

insert into tbl_user(ID, name)values(2, 'aihui');

insert into tbl_score(ID, score, subject)values(1, 90, '語文');

insert into tbl_score(ID, score, subject)values(1, 80, '數學');

insert into tbl_score(ID, score, subject)values(2, 86, '數學');insert into tbl_score(ID, score, subject)values(2, 96, '語文');select A.id,sum(B.score)as sumscore

from tbl_user A left join tbl_score B

on A.ID=B.ID

group by A.id

10.在PHP中,heredoc是一種特殊的字符串,它的結束標志必須____ 答:結束標識符所在的行不能包含任何其它字符除“;”

11.寫一個函數,能夠遍歷一個文件夾下的所有文件和子文件夾。

function my_scandir($dir)

{

$files=array();

if(is_dir($dir))

{

if($handle=opendir($dir))

{

while(($file=readdir($handle))!==false)

{

if($file!=“.” && $file!=“..”)

{

if(is_dir($dir.“/”.$file))

{

$files[$file]=my_scandir($dir.“/”.$file);}

else

{

$files[]=$dir.“/”.$file;

}

}

}

closedir($handle);

return $files;

}

}

}

print_r(my_scandir(“D:Program FilesInternet ExplorerMUI”));?>

第三篇:php程序員面試題(附答案)

PHP經典面試題(連載4).1 請說明 PHP 中傳值與傳引用的區別。什么時候傳值什么時候傳引用?

答: 傳值只是把某一個變量的值傳給了另一個變量,而引用則說明兩者指向了同一個地方。在PHP中error_reporting這個函數有什么作用?

答: The error_reporting()function sets the error_reporting directive at runtime.PHP has many levels of errors, using this function sets that level for the duration(runtime)of your script.3 請用正則表達式(Regular Expression)寫一個函數驗證電子郵件的格式是否正確。答:

EMAIL檢測

” method=“POST”> 電子郵件:

第四篇:PHP程序員面試題經典及答案集錦

都是經典

基礎題: 1.表單中 get與post提交方法的區別? 答:get是發送請求HTTP協議通過url參數傳遞進行接收,而post是實體數據,可以通過表單提交大量信息.2.session與cookie的區別? 答:session:儲存用戶訪問的全局唯一變量,存儲在服務器上的php指定的目錄中的(session_dir)的位置進行的存放

cookie:用來存儲連續訪問一個頁面時所使用,是存儲在客戶端,對于Cookie來說是存儲在用戶WIN的Temp目錄中的。

兩者都可通過時間來設置時間長短

3.數據庫中的事務是什么? 答:事務(transaction)是作為一個單元的一組有序的數據庫操作。如果組中的所有操作都成功,則認為事務成功,即使只有一個操作失敗,事務也不成功。如果所有操作完成,事務則提交,其修改將作用于所有其他數據庫進程。如果一個操作失敗,則事務將回滾,該事務所有操作的影響都將取消。

簡述題:

1、用PHP打印出前一天的時間格式是2006-5-10 22:21:21(2分)答:echo date('Y-m-d H:i:s', strtotime('-1 days'));

2、echo(),print(),print_r()的區別(3分)答:echo是PHP語句, print和print_r是函數,語句沒有返回值,函數可以有返回值(即便沒有用)print()只能打印出簡單類型變量的值(如int,string)print_r()可以打印出復雜類型變量的值(如數組,對象)echo 輸出一個或者多個字符串

3、能夠使HTML和PHP分離開使用的模板(1分)答:Smarty,Dwoo,TinyButStrong,Template Lite,Savant,phemplate,XTemplate

5、使用哪些工具進行版本控制?(1分)答:cvs,svn,vss;

6、如何實現字符串翻轉?(3分)答:echo strrev($a);

7、優化MYSQL數據庫的方法。(4分,多寫多得)答:

1、選取最適用的字段屬性,盡可能減少定義字段長度,盡量把字段設置NOT NULL,例如'省份,性別',最好設置為ENUM

2、使用連接(JOIN)來代替子查詢: a.刪除沒有任何訂單客戶:DELETE FROM customerinfo WHERE customerid NOT in(SELECT customerid FROM orderinfo)b.提取所有沒有訂單客戶:SELECT FROM customerinfo WHERE customerid NOT in(SELECT customerid FROM orderinfo)c.提高b的速度優化:SELECT FROM customerinfo LEFT JOIN orderid customerinfo.customerid=orderinfo.customerid WHERE orderinfo.customerid IS NULL

3、使用聯合(UNION)來代替手動創建的臨時表

a.創建臨時表:SELECT name FROM `nametest` UNION SELECT username FROM `nametest2`

4、事務處理: a.保證數據完整性,例如添加和修改同時,兩者成立則都執行,一者失敗都失敗

mysql_query(“BEGIN”);mysql_query(“INSERT INTO customerinfo(name)VALUES('$name1')”;mysql_query(“SELECT * FROM `orderinfo` where customerid=”.$id“);mysql_query(”COMMIT“);

5、鎖定表,優化事務處理: a.我們用一個 SELECT 語句取出初始數據,通過一些計算,用 UPDATE 語句將新值更新到表中。

包含有 WRITE 關鍵字的 LOCK TABLE 語句可以保證在 UNLOCK TABLES 命令被執行之前,不會有其它的訪問來對 inventory 進行插入、更新或者刪除的操作 mysql_query(”LOCK TABLE customerinfo READ, orderinfo WRITE“);mysql_query(”SELECT customerid FROM `customerinfo` where id=“.$id);mysql_query(”UPDATE `orderinfo` SET ordertitle='$title' where customerid=“.$id);mysql_query(”UNLOCK TABLES“);

6、使用外鍵,優化鎖定表

a.把customerinfo里的customerid映射到orderinfo里的customerid, 任何一條沒有合法的customerid的記錄不會寫到orderinfo里 CREATE TABLE customerinfo(customerid INT NOT NULL, PRIMARY KEY(customerid))TYPE = INNODB;CREATE TABLE orderinfo(orderid INT NOT NULL, customerid INT NOT NULL, PRIMARY KEY(customerid,orderid), FOREIGN KEY(customerid)REFERENCES customerinfo(customerid)ON DELETE CASCADE)TYPE = INNODB;注意:'ON DELETE CASCADE',該參數保證當customerinfo表中的一條記錄刪除的話同時也會刪除order 表中的該用戶的所有記錄,注意使用外鍵要定義事務安全類型為INNODB;

7、建立索引: 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[索引字段])

8、優化查詢語句

a.最好在相同字段進行比較操作,在建立好的索引字段上盡量減少函數操作

例子1: SELECT * FROM order WHERE YEAR(orderDate)<2008;(慢)SELECT * FROM order WHERE orderDate<”2008-01-01“;(快)例子2: SELECT * FROM order WHERE addtime/7<24;(慢)SELECT * FROM order WHERE addtime<24*7;(快)例子3: SELECT * FROM order WHERE title like ”%good%“;SELECT * FROM order WHERE title>=”good“ and name<”good“;

8、PHP的意思(送1分)答:PHP是一個基于服務端來創建動態網站的腳本語言,您可以用PHP和HTML生成網站主頁

9、MYSQL取得當前時間的函數是?,格式化日期的函數是(2分)答:now(),date()

10、實現中文字串截取無亂碼的方法。(3分)答:function GBsubstr($string, $start, $length){ if(strlen($string)>$length){ $str=null;$len=$start+$length;for($i=$start;$i<$len;$i++){ if(ord(substr($string,$i,1))>0xa0){ $str.=substr($string,$i,2);$i++;}else{ $str.=substr($string,$i,1);} } return $str.'...';}else{ return $string;} }

11、您是否用過版本控制軟件? 如果有您用的版本控制軟件的名字是?(1分)

12、您是否用過模板引擎? 如果有您用的模板引擎的名字是?(1分)答:用過,smarty

13、請簡單闡述您最得意的開發之作(4分)答:信息分類

14、對于大流量的網站,您采用什么樣的方法來解決訪問量問題?(4分)答:確認服務器硬件是否足夠支持當前的流量,數據庫讀寫分離,優化數據表, 程序功能規則,禁止外部的盜鏈,控制大文件的下載,使用不同主機分流主要流量

15、用PHP寫出顯示客戶端IP與服務器IP的代碼1分)答:打印客戶端IP:echo $_SERVER[‘REMOTE_ADDR’];或者: getenv('REMOTE_ADDR');打印服務器IP:echo gethostbyname(” 語言中,頁面頭部的 meta 標記可以用來輸出文件的編碼格式,以下是一個標準的 meta 語句

請使用 PHP 語言寫一個函數,把一個標準 HTML 頁面中的類似 meta 標記中的 charset 部分值改為 big5

請注意:

1.需要處理完整的 html 頁面,即不光此 meta 語句

2.忽略大小寫

3.' 和 “ 在此處是可以互換的

4.'Content-Type' 兩側的引號是可以忽略的,但 'text/html;charset=gbk' 兩側的不行

5.注意處理多余空格

3.寫一個函數,算出兩個文件的相對路徑

如 $a = '/a/b/c/d/e.php';

$b = '/a/b/12/34/c.php';

計算出 $b 相對于 $a 的相對路徑應該是../../c/d將()添上 答:function getRelativePath($a, $b){ $returnPath = array(dirname($b));$arrA = explode('/', $a);$arrB = explode('/', $returnPath[0]);for($n = 1, $len = count($arrB);$n < $len;$n++){ if($arrA[$n]!= $arrB[$n]){ break;} } if($len$n, '..'));}

$returnPath = array_merge($returnPath, array_slice($arrA, $n));return implode('/', $returnPath);} echo getRelativePath($a, $b);填空題: 1.在PHP中,當前腳本的名稱(不包括路徑和查詢字符串)記錄在預定義變量__$_SERVER['PHP_SELF']__中;而鏈接到當前頁面的URL記錄在預定義變量__$_SERVER['HTTP_REFERER']__ 中

2.執行程序段將輸出__0__。

3.在HTTP 1.0中,狀態碼 401 的含義是____;如果返回“找不到文件”的提示,則可用 header 函數,其語句為____。

4.數組函數 arsort 的作用是__對數組進行逆向排序并保持索引關系__;語句 error_reporting(2047)的作用是__報告所有錯誤和警告__。5.PEAR中的數據庫連接字符串格式是____。

6.寫出一個正則表達式,過慮網頁上的所有JS/VBS腳本(即把scrīpt標記及其內容都去掉):preg_replace(” /].*?>.*?/si“, ”newinfo“, $script);7.以Apache模塊的方式安裝PHP,在文件http.conf中首先要用語句____動態裝載PHP模塊,然后再用語句____使得Apache把所有擴展名為php的文件都作為PHP腳本處理。

LoadModule php5_module ”c:/php/php5apache2.dll“ , AddType application/x-httpd-php.php, 8.語句 include 和 require 都能把另外一個文件包含到當前文件中,它們的區別是____;為了避免多次包含同一文件,可以用語句__require_once||include_once__來代替它們。

9.類的屬性可以序列化后保存到 session 中,從而以后可以恢復整個類,這要用到的函數是____。

10.一個函數的參數不能是對變量的引用,除非在php.ini中把__allow_call_time_pass_reference boolean__設為on.11.SQL中LEFT JOIN的含義是__自然左外鏈接__。如果 tbl_user記錄了學生的姓名(name)和學號(ID),tbl_score記錄了學生(有的學生考試以后被開除了,沒有其記錄)的學號(ID)和考試成績(score)以及考試科目(subject),要想打印出各個學生姓名及對應的的各科總成績,則可以用SQL語句____。

12.在PHP中,heredoc是一種特殊的字符串,它的結束標志必須____。編程題: 13.寫一個函數,能夠遍歷一個文件夾下的所有文件和子文件夾。答: function my_scandir($dir){ $files = array();if($handle = opendir($dir)){ while(($file = readdir($handle))!== false){ if($file!= ”..“ && $file!= ”.“){ if(is_dir($dir.”/“.$file)){ $files[$file] = scandir($dir.”/“.$file);}else { $files[] = $file;} } } closedir($handle);return $files;} } 14.簡述論壇中無限分類的實現原理。答:

function Get_Category($category_id = 0,$level = 0, $default_category = 0){ global $DB;$sql = ”SELECT * FROM category ORDER BY categoryID DESC“;$result = $DB->query($sql);while($rows = $DB->fetch_array($result)){ $category_array[$rows[categoryParentID]][$rows[categoryID]] = array('id' => $rows[categoryID], 'parent' => $rows[categoryParentID], 'name' => $rows [categoryName]);} if(!isset($category_array[$category_id])){ return ”“;} foreach($category_array[$category_id] AS $key => $category){ if($category['id'] == $default_category){ echo ”/n“;} else { echo ”>“.$category['name'].”/n“;} Get_Category($key, $level + 1, $default_category);} unset($category_array[$category_id]);} /* 函數返回的數組格式如下所示: Array([1] => Array([id] => 1 [name] => 一級類別 [level] => 0 [ParentID] => 0)[4] => Array([id] => 4 [name] => 二級類別 [level] => 1 [ParentID] => 1)[9] => Array([id] => 9 [name] => 哈哈 [level] => 2 [ParentID] => 4)[3] => Array([id] => 3 [name] => 二級類別 [level] => 1 [ParentID] => 1)[8] => Array([id] => 8 [name] => aqqqqqd [level] => 2 [ParentID] => 3)[2] => Array([id] => 2 [name] => 二級類別 [level] => 1 [ParentID] => 1)[7] => Array([id] => 7 [name] => 234234 [level] => 2 [ParentID] => 2)[6] => Array([id] => 6 [name] => 333332 [level] => 2 [ParentID] => 2)[5] => Array([id] => 5 [name] => 三級類別 [level] => 2 [ParentID] => 2)[10] => Array([id] => 10 [name] => 66333666 [level] => 3 [ParentID] => 5))*/ //指定分類id,然后返回數組

function Category_array($category_id = 0,$level=0){ global $DB;$sql = ”SELECT * FROM category ORDER BY categoryID DESC“;$result = $DB->query($sql);while($rows = $DB->fetch_array($result)){ $category_array[$rows['categoryParentID']][$rows['categoryID']] = $rows;} foreach($category_array AS $key=>$val){ if($key == $category_id){ foreach($val AS $k=> $v){ $options[$k] = array('id' => $v['categoryID'], 'name' => $v['categoryName'], 'level' => $level, 'ParentID'=>$v['categoryParentID']);$children = Category_array($k, $level+1);if(count($children)> 0){ $options = $options + $children;} } } } unset($category_array[$category_id]);return $options;} ?> array('1' => array('id' => 1, 'parent' => 0, 'name' => '1111'), '2' => array('id' => 2, 'parent' => 0, 'name' => '2222'), '4' => array('id' => 4, 'parent' => 0, 'name' => '4444')), '1' => array('3' => array('id' => 3, 'parent' => 1, 'name' => '333333'), '5' => array('id' => 5, 'parent' => 1, 'name' => '555555')), '3' => array('6' => array('id' => 6, 'parent' => 3, 'name' => '66666'), '7' => array('id' => 7, 'parent' => 3, 'name' => '77777')), '4' => array('8' => array('id' => 8, 'parent' => 4, 'name' => '8888'), '9' => array('id' => 9, 'parent' => 4, 'name' => '9999')));if(!isset($arr[$category_id])){ return ”“;}

foreach($arr[$category_id] AS $key => $cate){ if($cate['id'] == $default_category){ $txt = ”

if($level > 0){ $txt1 = ”>“.str_repeat(”-“, $level).” “.$cate['name'].”/n“;}else{ $txt1 = ”>“.$cate['name'].”/n“;} $val = $txt.$txt1;echo $val;self::Get_Category($key, $level + 1, $default_category);} }

function getFlush($category_id = 0,$level = 0, $default_category = 0){

ob_start();self::Get_Category($category_id ,$level, $default_category);$out = ob_get_contents();ob_end_clean();return $out;} } $id =$_GET['id'];echo ”";?>

第五篇:PHP程序員面試題

北京融入網絡科技有限公司

PHP工程師面試題

1、請寫一個實現中文字串截取無亂碼的方法。(超出部分用’…..’替換)。

2、ThinkPHP框架中,下列定義有什么不同?

$userModel = M(“User”);

$userMode l= D(“User”);

3、如果讓你模擬登陸微信公眾平臺并設置微信的開發模式中的URL和Token,你會如何去做?(思路或代碼皆可)。

4、談談對你對PHP的認識或你擅長的技術。

5、假設有一個博客系統,數據庫存儲采用mysql,用戶數量為1000萬,預計文章總數為10億,每天有至少10萬的更新量,每天訪問量為5000萬,對數據庫的讀寫操作的比例超過10:1,你如何設計該系統,以確保其系統高效,穩定的運行?

提示:可以從數據庫設計,系統框架,及網絡架構方面進行描述,可以自由發揮。

6、你經常去那些網站?有沒有自己的博客或git 開源項目。

/ 1

下載php程序員面試題(b卷_附答案)word格式文檔
下載php程序員面試題(b卷_附答案).doc
將本文檔下載到自己電腦,方便修改和收藏,請勿使用迅雷等下載。
點此處下載文檔

文檔為doc格式


聲明:本文內容由互聯網用戶自發貢獻自行上傳,本網站不擁有所有權,未作人工編輯處理,也不承擔相關法律責任。如果您發現有涉嫌版權的內容,歡迎發送郵件至:645879355@qq.com 進行舉報,并提供相關證據,工作人員會在5個工作日內聯系你,一經查實,本站將立刻刪除涉嫌侵權內容。

相關范文推薦

    PHP程序員面試題

    PHP程序員面試題 一、選擇題1、下列不屬于PHP的開始結束標記的是:( ) A、 B、 C、 D、2、下列程序的輸出結果為( ) A、456 B、123 C、124 D、會報錯4、下列代碼的輸出結果為( ) A......

    PHP程序員面試題(精選5篇)

    PHP方面: 1:echo print print_r的區別 Echo是PHP語句,print與print_r是函數,語句沒有返回值,函數可以有返回值。Print只能打印簡單類型變量的值。 Print_r可以打印復雜變量值(數組......

    PHP程序員筆試題(附答案)

    普通PHP程序員筆試題 標簽:程序員PHP面試2009-02-06 15:19 1. 用PHP打印出前一天的時間,打印格式是2007年5月10日 22:21:21 2. PHP代碼如下: $a="hello"; $b=&$a; unset($b);......

    php程序員 一度搜索面試題

    一.必答題 1.(算法題)有1~5000一組亂序數列,請使用偽代碼對該數進行排列 2.(算法題)公雞3元每只,母雞5元每只,小雞1元3只,一百元錢買一百只雞,請用偽代碼寫出求公雞,母雞和小雞的數目 3......

    PHP經典面試題(基礎型)附答案(精選5篇)

    PHP經典面試題(基礎型I)附答案 求職與招聘 往往少不了面試與筆試,作為一個php程序員、多多少少都會有類似的經歷??以下是本人收集并整理的PHP面試題目,希望對同行們有所幫助,找......

    php工程師面試題及答案

    PHP全稱:Hypertext Preprocessor,是一種用來開發動態網站的服務器腳本語言。下面是小編整理的php工程師面試題及答案,希望對大家有幫助!【1 】Memcached、redis的使用和理解Memc......

    PHP程序員

    **的個人簡歷個人資料 姓名: **電子郵件: ******@qq.com 名族: 漢出生日期: 1991/1/3 學歷: 本科居住地址: 深圳福田 性別: 男手機號碼: 186***77394求職意向 到崗時間:即時 期望職位......

    PHP面試題

    PHP程序員初級面試題 一、 解釋一下語句作用,并標示出以下哪一句不會把 John 新增到 users 陣列?$users[] = 'john'; array_add($users,?john?);array_push($users,?john......

主站蜘蛛池模板: 国产女人18毛片水真多18精品| 乌克兰少妇xxxx做受| 国产精品久久久久久婷婷| 欧美天天综合色影久久精品| 久久久久人妻一区精品| 久久亚洲精品成人无码网站夜色| 无码国产精品久久一区免费| 欧美婷婷六月丁香综合色| 成人美女黄网站色大免费的| 插我舔内射18免费视频| 超级碰碰| 97久久婷婷五月综合色d啪蜜芽| 亚洲精品久久久中文字幕痴女| 97久久超碰国产精品旧版麻豆| 国产成人免费a在线视频| 人禽交 欧美 网站| 国产亚洲精久久久久久无码77777| 成年女人免费碰碰视频| 99精品人妻无码专区在线视频区| 久久人妻精品白浆国产| 四虎国产精品免费久久| 欧洲熟妇乱xxxxx大屁股7| 消息称老熟妇乱视频一区二区| 色爱情人网站| 色综合久久中文娱乐网| 欧美成aⅴ人高清怡红院| 在线看片免费人成视频久网下载| 欧美野性肉体狂欢大派对| 人人人妻人人人妻人人人| 无码人妻品一区二区三区精99| 久久人人97超碰国产公开| 亚洲成av人片在线观看麦芽| 久久天天躁狠狠躁夜夜av浪潮| 东北女人啪啪对白| 欧美肥妇毛多水多bbxx| 亚洲看片lutube在线观看| 国产在线国偷精品免费看| 国产精品亚洲玖玖玖在线观看| 日本一本免费一区二区三区免| 亚洲日韩亚洲另类激情文学| 国产无遮挡18禁无码网站免费|