php隨堂試題以及答案,php隨堂試題以及答案在哪裡

本文目錄一覽:

PHP程序員上機面試題(並附答案,回答好的加分)

某大公司的PHP面試題

管理提醒: 本帖被 haowubai 執行取消置頂操作(2009-07-30)

1. 如何用php的環境變量得到一個網頁地址的內容?ip地址又要怎樣得到?

[php]

echo $_SERVER [‘PHP_SELF’];

echo $_SERVER [‘SERVER_ADDR’];

[/php]

2. 求兩個日期的差數,例如2007-2-5 ~ 2007-3-6 的日期差數

[php]

$begin=strtotime(‘2007-2-5’);

$end=strtotime(‘2007-3-6’);

echo ($end-$begin)/(24*3600);

[/php]

3. 請寫一個函數,實現以下功能:

字符串「open_door」 轉換成 「OpenDoor」、」make_by_id」 轉換成 」MakeById」。

[php]

function changeStyle( $str) {

/*$str = str_replace ( “_”, ” “, $str );

$str = ucwords ( $str );

$str = str_replace ( ” “, “”, $str );

return $str;*/

$arrStr=explode(‘_’,$str);

foreach($arrStr as $key=$value){

$arrStr[$key]=strtoupper(substr($value,0,1)).substr($value,1);

}

return implode(”,$arrStr);

}

$s = “open_door”;

echo changeStyle ( $s );

[/php]

4. 要求寫一段程序,實現以下數組$arr1轉換成數組$arr2:

[php]$arr1 = array (

‘0’ = array (‘fid’ = 1, ‘tid’ = 1, ‘name’ =’Name1′ ),

‘1’ = array (‘fid’ = 1, ‘tid’ = 2 , ‘name’ =’Name2′ ),

‘2’ = array (‘fid’ = 1, ‘tid’ = 5 , ‘name’ =’Name3′ ),

‘3’ = array (‘fid’ = 1, ‘tid’ = 7 , ‘name’ =’Name4′ ),

‘4’ = array (‘fid’ = 3, ‘tid’ = 9, ‘name’ =’Name5′ )

);

$arr2 = array (

‘0’ = array (

‘0’ = array ( ‘tid’ = 1, ‘name’ = ‘Name1’),

‘1’ = array ( ‘tid’ = 2, ‘name’ = ‘Name2’),

‘2’ = array ( ‘tid’ = 5, ‘name’ = ‘Name3’),

‘3’ = array ( ‘tid’ = 7, ‘name’ = ‘Name4’)

),

‘1’ = array (

‘0’ = array ( ‘tid’ = 9, ‘name’ = ‘Name5’ )

)

);

?php

$arr1 = array (

‘0’ = array (‘fid’ = 1, ‘tid’ = 1, ‘name’ =’Name1′ ),

‘1’ = array (‘fid’ = 1, ‘tid’ = 2 , ‘name’ =’Name2′ ),

‘2’ = array (‘fid’ = 1, ‘tid’ = 5 , ‘name’ =’Name3′ ),

‘3’ = array (‘fid’ = 1, ‘tid’ = 7 , ‘name’ =’Name4′ ),

‘4’ = array (‘fid’ = 3, ‘tid’ = 9, ‘name’ =’Name5′ )

);

function changeArrayStyle($arr){

foreach($arr as $key=$value){

$result[$value[‘fid’]][]=$value;

}

return array_values($result);

}

$arr2=changeArrayStyle($arr1);

echo “pre”;

var_dump($arr2);

[/php]

5. 請簡述數據庫設計的範式及應用。

一般第3範式就足以,用於表結構的優化,這樣做既可以避免應用程序過於複雜同時也避免了SQL語句過於龐大所造成系統效率低下。

ANSWER:

第一範式:若關係模式R的每一個屬性是不可再分解的,再屬於第一範式。

第二範式:若R屬於第一範式,且所有的非碼屬性都完全函數依賴於碼屬性,則為第二範式。

第三範式:若R屬於第二範式,且所有的非碼屬性沒有一個是傳遞函數依賴於候選碼,則屬於第三範式。

6.一個表中的Id有多個記錄,把所有這個id的記錄查出來,並顯示共有多少條記錄數,用SQL語句及視圖、存儲過程分別實現。

存儲過程:

[php]

DELIMITER //

create procedure proc_countNum(in columnId int,out rowsNo int)

begin

select count(*) into rowsNo from member where member_id=columnId;

end

call proc_countNum(1,@no);

select @no;

[/php]

視圖:

create view v_countNum as select member_id,count(*) as countNum from member group by member_id

select countNum from v_countNum where member_id=1

7 表中有A B C三列,用SQL語句實現:當A列大於B列時選擇A列否則選擇B列,當B列大於C列時選擇B列否則選擇C列。

[php]select

case

when first_namemiddle_name then

case when first_namelast_name then first_name

else last_name end

else

case when middle_namelast_name then middle_name else last_name

end

end as name

from member

[/php]

8請簡述項目中優化sql語句執行效率的方法,從哪些方面,sql語句性能如何分析?

ANSWER: sql優化有鳥用,不如直接加索引。

9 如果模板是用smarty模板。怎樣用section語句來顯示一個名為$data的數組。比如:

[php]$data = array(

[0] = array( [id]=8 [name]=』name1′)

[1] = array( [id]=10 [name]=』name2′)

[2] = array( [id]=15 [name]=』name3′)

……

)[/php]

寫出在模板頁的代碼? 若用foreach語句又要怎樣顯示呢?

占無答案.

10 寫一個函數,能夠遍歷一個文件夾下的所有文件和子文件夾。(目錄操作)

[php] ?php

$d = dir(dirname(__file__));

//echo “Handle: ” . $d-handle . “\n”;

//echo “Path: ” . $d-path . “\n”;

while ( false !== ($entry = $d-read ()) ) {

echo $entry . “br /”;

}

$d-close ();

[/php]

11 兩張表 city表和province表。分別為城市與省份的關係表。

city:

id City Provinceid

1 廣州 1

2 深圳 1

3 惠州 1

4 長沙 2

5 武漢 3

………. 廣州

province:

id Province

1 廣東

2 湖南

3 湖北

……….

(1) 寫一條sql語句關係兩個表,實現:顯示城市的基本信息。?

(2) 顯示字段:城市id ,城市名, 所屬省份 。

如:

Id(城市id) Cityname(城市名) Privence(所屬省份)

。。。。。。。。。

。。。。。。。。。

(2)如果要統計每個省份有多少個城市,請用group by 查詢出來。?

顯示字段:省份id ,省份名,包含多少個城市。

ANSWER:

1.select A.id,A.Cityname,B.Province from city A,province B where A.provinceid=B.id

2.select B.id,B.Province,count(*) as num from city A,province B where A.provinceid=B.id group by B.id

12. 按照你的經驗請簡述軟件工程進行軟件開發的步驟。以下工具Rational Rose、PowerDesigner、Project、VSS或CVS、TestDirector使用過那種,有缺點是什麼?

公司用dbdesigner及cvs,測試管理工具用的是Mantis

13. 請簡述操作系統的線程與進程的區別。列舉LINUX下面你使用過的軟件?

14. 請使用偽語言結合數據結構冒泡排序法對以下一組數據進行排序 10 2 36 14 10 25 23 85 99 45。

[php]function bubble_sort( $arr){

$number=count($arr);

for($i=0;$i$number-1;$i++){

for($j=0;$j$number-1-$i;$j++){

if($arr[$j]$arr[$j+1]){

$tmp=$arr[$j];

$arr[$j]=$arr[$j+1];

$arr[$j+1]=$tmp;

}

}

}

}

$str=”10 2 36 14 10 25 23 85 99 45″;

$arr=explode(” “,$str);

bubble_sort($arr);

echo “pre”;

var_dump($arr);

[/php]

PHP數組例題求教

首先,有個0元素,意思是存放這個人的總得分的意思,

最後要總分的時候,比如 a = array(5, 7.7, 8, 0); 只要a[3]就好了,明白?

然後下面的。本例子申請了一個二維數組,相當於a[8][4]

前面的8代表有八個人,也就是例子中的8個array,4是每個人的數據項,

就是第一輪,第二輪,第三輪和總分。

下面開始for循環,首先按人進行循環

將每個人的三輪成績進行循環加和,得到的總分放到每個人的數組的第四項。

最後再按人循環一次,把每個人的第四項,也就是總分輸出出來,這樣OK?

php面試題解答

1,

var x=document.getElementById(“img1”);

var title=document.getElementById(“img1”).title;

var sina_title=document.getElementById(“img1”).sina_title;

2,serialize(),unserialize();

3,編碼方式不同,urlencode()將字串以URL編碼。例如空格就會變成加號。

rawurlencode()將url編碼成url的字符串專用格式,特殊字符迴轉換成百分號後面加兩個十六子介數字的格式。

4,strip_tags(),html_entity_decode();

5,$str=preg_replace(“/\script.*\.*\\/script\/i”,””,$str);

6,左連接,左連接的表如果沒有匹配的數據不影響結果。

7

SELECT name,score FROM tl_user LEFT JOIN tl_score ON tl_user.ID=tl_score.ID

7 system(),exec(),passthru()

8,json_decode ,json_encode

9 isset() empty()

10 後者的權限大於前者,後者是OFF的話,前者就算是E-ALL也沒用。

11,$_SERVER[‘REMOTE_ADDR’];

12,incov()

echo iconv(“gbk”,””UTF-8,”我們”);

mb_convert_encoding($str, “GBK”, “UTF-8”)

13 explode() split() ;implode() join()

14 注意事項挺多的,懶得寫。

1,超時,服務器已經關閉連接

2 靜態表字段長度固定,自動填充,讀寫速度很快,便於緩存和修復,但比較占硬盤,動態表是字段長度不固定,節省硬盤,但更複雜,容易產生碎片,速度慢,出問題後不容易重建。

3InnoDB和MyISAM是在使用MySQL最常用的兩個表類型,各有優缺點,視具體應用而定。基本的差別為:MyISAM類型不支持事務處理等高級處理,而InnoDB類型支持。MyISAM類型的表強調的是性能,其執行數度比InnoDB類型更快,但是不提供事務支持,而InnoDB提供事務支持已經外部鍵等高級數據庫功能。

MyIASM是IASM表的新版本,有如下擴展:

二進制層次的可移植性。

NULL列索引。

對變長行比ISAM表有更少的碎片。

支持大文件。

更好的索引壓縮。

更好的鍵嗎統計分佈。

更好和更快的auto_increment處理。

1.MySQL最大的優勢在於MyISAM引擎下的簡單SELECT,INSERT和UPDATE快速操作

2.MyISAM類型的數據文件可以在不同操作系統中COPY,這點很重要,布署的時候方便點。

以下是一些細節和具體實現的差別:

1.InnoDB不支持FULLTEXT類型的索引。

2.InnoDB 中不保存表的具體行數,也就是說,執行select count(*) from table時,InnoDB要掃描一遍整個表來計算有多少行,但是MyISAM只要簡單的讀出保存好的行數即可。注意的是,當count(*)語句包含 where條件時,兩種表的操作是一樣的。

3.對於AUTO_INCREMENT類型的字段,InnoDB中必須包含只有該字段的索引,但是在MyISAM表中,可以和其他字段一起建立聯合索引。

4.DELETE FROM table時,InnoDB不會重新建立表,而是一行一行的刪除。

5.LOAD TABLE FROM MASTER操作對InnoDB是不起作用的,解決方法是首先把InnoDB表改成MyISAM表,導入數據後再改成InnoDB表,但是對於使用的額外的InnoDB特性(例如外鍵)的表不適用。

另外,InnoDB表的行鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的範圍,InnoDB表同樣會鎖全表,例如update table set num=1 where name like 「%aaa%」

以暫對存儲引擎的認識,覺得 InnoDB 支持外鍵,在數據量可以用「龐大」來形容時,在有良好的 INDEX 的基礎上,InnoDB 的查詢速度應該比 MyISAM 要快。

在 Falcon 有穩定版本前,我想 MyISAM 是一個可用的選擇方案。

任何一種表都不是萬能的,只用恰當的針對業務類型來選擇合適的表類型,才能最大的發揮MySQL的性能優勢

3, 都是1 ^^懶得回答了,睡覺去。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/293179.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-25 18:39
下一篇 2024-12-25 18:39

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • 學堂雲Python語言程序設計答案

    學堂雲Python語言程序設計是一門重要的計算機專業課程。它涵蓋了Python語言及其應用,包括基礎語法、函數、文件處理、數據結構、圖形界面和網絡編程等內容。在學習中,我們經常會需…

    編程 2025-04-29
  • 南京郵電大學Python慕課答案

    本文將詳細闡述南京郵電大學Python慕課答案,為大家提供學習Python課程的參考。 一、應用範圍 Python是一種高級通用編程語言,應用範圍廣泛,包括Web開發、數據分析與科…

    編程 2025-04-28
  • 大學化學科學出版社教材答案

    本文將從以下幾個方面對大學化學科學出版社教材答案進行詳細闡述,幫助您更好地應對學習中的問題: 一、獲取教材答案的渠道 學習過程中,有時候會遇到難以解答的問題,這時候就需要查看教材答…

    編程 2025-04-28
  • Python初探答案第七關——解題指南

    Python初探答案第七關是一道典型的Python編程題目,涉及字符串的判斷和操作。下面我們將從多個方面詳細闡述這道題目的解題方法。 一、題目分析 首先,我們需要仔細研究題目要求以…

    編程 2025-04-28
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • 小甲魚Python課後作業及答案百度雲

    小甲魚課程是一門 Python 開發的視頻課程,自 2008 年以來一直廣受歡迎。本文主要介紹小甲魚 Python 課後作業及答案所在的百度雲地址。以下是詳細內容: 一、百度雲地址…

    編程 2025-04-27
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若服務器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27

發表回復

登錄後才能評論