施公奇案
這是最常見(jiàn)的內(nèi)連接查詢 select a.fielda, b.fieldb from a, b where a.id=b.id : 但問(wèn)題是,popt,poval,pa這些都是 數(shù)據(jù)庫(kù) 中沒(méi)有的表啊 回答: popt, poval, pa是別名 例如這一句: select a.fielda, b.fieldb from asdf a, bvcx b where a.id=b.id a是 asdf 的別名, b 是bvcx 的別名. : 可是別名是怎么獲取或者說(shuō)怎么定義的 回答: 由用戶自定義. 例如你想叫某人的 外號(hào) , 你自己給他起外號(hào)就可以了 補(bǔ)充: select a.fielda, b.fieldb from asdf a, bvcx b where a.id=b.id select a.fielda, b.fieldb from asdf as a, bvcx as b where a.id=b.id from 表名 [as] 別名 [as]可以省略 : 請(qǐng)問(wèn)下,用別名進(jìn)行操作,有什么好處嗎? 回答: 短 : 就這樣啊... 回答: 呃..還有可以避免重復(fù)的名字出現(xiàn) 例如 select a.* from asdf a, asdf b where a.parent = b.parent and a.id=123 補(bǔ)充: 上例如果不使用別名就無(wú)法寫where 子句 了
孟公威
1.debug_zval_dump(),它與var_dump()的區(qū)別就是它新增了一個(gè)值refcount,即記錄變量被引用的次數(shù)。同時(shí)它還可以打印幾個(gè)變量。 如果你連引用計(jì)數(shù)器都不懂的話,請(qǐng)閱讀:PHP垃圾回收機(jī)制引用計(jì)數(shù)器概念2.debug_print_backtrace() debug_backtrace() 只是前者直接打印出來(lái)了而已。查看整個(gè)程序的調(diào)用棧,用來(lái)查看瞬間函數(shù)調(diào)用棧,方便查錯(cuò)。
蹋頓
高級(jí)php工程師可以往幾個(gè)方向去發(fā)展:1.深度方向一個(gè)工程師要往高階發(fā)展,必須同時(shí)強(qiáng)化幾個(gè)技術(shù)能力:設(shè)計(jì)能力:懂得如何利用分層、面向?qū)ο蟆⒃O(shè)計(jì)模式等設(shè)計(jì)組織代碼編碼能力:熟悉php語(yǔ)法特性,知道怎么用一兩行代碼代替初級(jí)開(kāi)發(fā)者十幾上百行代碼。工程能力:學(xué)會(huì)如何快速構(gòu)建工程,學(xué)會(huì)如何構(gòu)建可讀、可擴(kuò)展性的工程,學(xué)會(huì)如何避免埋坑給后人,學(xué)會(huì)如何與人協(xié)作維護(hù)工程,學(xué)會(huì)如何保證工程質(zhì)量,學(xué)會(huì)如何權(quán)衡利弊,學(xué)會(huì)如何在困難面前妥協(xié)。抽象能力:初級(jí)開(kāi)發(fā)者通常會(huì)等到邏輯重復(fù)時(shí)再抽象封裝(甚至怕拖進(jìn)度或者懶惰而放棄),而高級(jí)開(kāi)發(fā)者通常一開(kāi)始寫出的邏輯就為了以后的重用,并且深知一開(kāi)始多付出的思考設(shè)計(jì)時(shí)間最終都會(huì)因?yàn)閺?fù)用得到回報(bào)。很多開(kāi)發(fā)框架就是一步步抽象/埋坑/優(yōu)化而來(lái)的。兄弟連教育PHP培訓(xùn)多年。架構(gòu)能力:一個(gè)業(yè)務(wù)系統(tǒng)如何劃分模塊,模塊之間如何協(xié)作通信,每個(gè)模塊的技術(shù)選型如何做,系統(tǒng)細(xì)節(jié)如何規(guī)避問(wèn)題等等。優(yōu)化能力:學(xué)會(huì)如何評(píng)估、分析、提升系統(tǒng)性能。優(yōu)化途徑很多,產(chǎn)品功能優(yōu)化、業(yè)務(wù)邏輯優(yōu)化、基礎(chǔ)技術(shù)優(yōu)化、操作系統(tǒng)底層硬件的優(yōu)化等等。2.廣度方向php開(kāi)發(fā)基本上離不開(kāi)操作系統(tǒng)、存儲(chǔ)、緩存、網(wǎng)絡(luò)、webserver等等配套設(shè)施,因此這也是高階必備技能。一旦業(yè)務(wù)系統(tǒng)出問(wèn)題了,必須要能快速定位解決(不一定自己解決,但要知道找到哪個(gè)負(fù)責(zé)人來(lái)解決)。比如存儲(chǔ)mysql,高級(jí)開(kāi)發(fā)者會(huì)懂得利用索引、利用分表分庫(kù)提高查詢性能,懂得負(fù)載均衡和災(zāi)備提高性能提高可靠性(雖然是DBA的工作,但了解了有助于出問(wèn)題時(shí)排查)比如緩存,高級(jí)開(kāi)發(fā)者懂得如何有效且最大限度利用緩存系統(tǒng)提高應(yīng)用性能。比如http,初級(jí)開(kāi)發(fā)者往往只懂得http網(wǎng)絡(luò)請(qǐng)求就只一去一回兩個(gè)包,高級(jí)開(kāi)發(fā)者會(huì)去深究網(wǎng)絡(luò)七層模型、會(huì)深究http請(qǐng)求的各個(gè)環(huán)節(jié)(DNS、三次握手等等)比如web前端,學(xué)習(xí)如何依靠瀏覽器緩存、CDN緩存、壓縮代碼、合并文件等等提高前端性能,學(xué)習(xí)如何進(jìn)行前端安全攻防。3,軟素質(zhì)懂得團(tuán)隊(duì)管理,項(xiàng)目管理,溝通技巧等等。
玄陰峒
一個(gè)普通的PHP程序員,除了PHP本身的知識(shí)外,需要數(shù)據(jù)庫(kù)的基本知識(shí)。 一個(gè)PHP高級(jí)程序員要掌握的知識(shí)除普通的PHP程序員知識(shí)外,至少還要學(xué)習(xí)JavaScript、Ajax、CSS和XML等方面的知識(shí)。 有一點(diǎn)編程基礎(chǔ)學(xué)習(xí)PHP是比較容易的,首先學(xué)會(huì)配置編程環(huán)境,如果不會(huì),可先找一些集成的編程環(huán)境練習(xí)。PHP與C語(yǔ)言非常接近,逐漸學(xué)習(xí),由易到難。做出一個(gè)象樣的東西大概快一點(diǎn)的三個(gè)月,慢一點(diǎn)的半年吧。
華雄
當(dāng)然是好好學(xué)習(xí)了,只有懂得能成更好的發(fā)展:1、熟練掌握HTML/CSS/Javascript等網(wǎng)頁(yè)的基本元素,可自行制作完整的網(wǎng)頁(yè)。2、熟練配置php的開(kāi)發(fā)環(huán)境.并選擇一種適合自己的開(kāi)發(fā)工具。3、熟悉php語(yǔ)法,理解動(dòng)態(tài)網(wǎng)頁(yè)的運(yùn)作機(jī)制。4、熟練掌握如何將HTML/CSS/Javascript與php語(yǔ)言完美結(jié)合起來(lái),完成動(dòng)態(tài)頁(yè)面的制作。5、熟悉數(shù)據(jù)庫(kù)MySQL,并能沒(méi)計(jì)數(shù)據(jù)庫(kù),能靈活使用常見(jiàn)的SQL語(yǔ)句。6、不斷的練習(xí).能熟練使川php的大部分函數(shù)。7、熟練掌握php中的模板技術(shù),如Smarty模板等。8、能獨(dú)薩開(kāi)發(fā)一個(gè)功能齊全的動(dòng)態(tài)站點(diǎn)。想要學(xué)習(xí)PHP的話線下學(xué)習(xí)費(fèi)用高昂、地域限制,建議選擇線上平臺(tái)。如今線上學(xué)習(xí)無(wú)論是就業(yè)還是教學(xué)均已完善??鄱W(xué)堂具有完整系統(tǒng)的PHP開(kāi)發(fā)培訓(xùn)視頻教程,頂級(jí)行內(nèi)大牛為學(xué)員們?cè)O(shè)定了可視化的學(xué)習(xí)線路直通車,讓沒(méi)有學(xué)習(xí)方向的學(xué)子一目了然,最快的進(jìn)入PHP領(lǐng)域大門。
馬宇
百度教程一大堆沒(méi)必要一定去培訓(xùn)班
施林
雖然這些對(duì)沒(méi)有學(xué)過(guò)的學(xué)生來(lái)說(shuō)是比較難,但是沒(méi)有試過(guò)怎么知道難不難呢。我同學(xué)的同學(xué)他是在中育美佳計(jì)算機(jī)學(xué)校學(xué)的,學(xué)得認(rèn)真,對(duì)他來(lái)說(shuō)就不是很難。那的老師教的細(xì)心,認(rèn)真。只要好好學(xué)不成問(wèn)題。
殺戒
最方便快捷的方法就是找個(gè)懂這個(gè)人給你當(dāng)老師,如果身邊沒(méi)有這樣的人選,還可以考慮去報(bào)個(gè)專業(yè)的班系統(tǒng)學(xué)習(xí),估計(jì)也就是幾個(gè)月時(shí)間就能獨(dú)當(dāng)一面啦。
蔣奇
一、平靜的心態(tài)
和所有程序員一樣,要寫一手好的程序,沒(méi)有好的心態(tài)是不行的。
遇事不可急躁,不可輕言放棄。
在程序開(kāi)發(fā)過(guò)程中,尤其是初中級(jí)程序員,寫出的程序或架構(gòu)會(huì)遇到很多問(wèn)題,其中一些問(wèn)題比較弱智,而有些問(wèn)題根本沒(méi)有碰到過(guò),于是不可太過(guò)急躁,應(yīng)該逐個(gè)排查問(wèn)題的最初源泉,將其干掉。急躁的心態(tài)去開(kāi)發(fā)系統(tǒng)是對(duì)項(xiàng)目的一種不負(fù)責(zé)。急躁會(huì)讓人學(xué)會(huì)將就,讓人學(xué)會(huì)逃避。而我個(gè)人北京兩年的簡(jiǎn)單生活,給我其中一個(gè)最大的歷練也就是:我的心態(tài)更加平靜了。
相信,這樣的心態(tài)也會(huì)有助于你其他方面的處事能力。
為什么將心態(tài)列入其中,我是想說(shuō)明:它不同于銷售的職能,需要很大激情澎湃,而是需要靜靜的思考。
二、一套爛熟于心的問(wèn)題解決思路
曾經(jīng)有位程序開(kāi)發(fā)的同事在QQ簽名中寫到:每解決一個(gè)bug,就給自己一個(gè)提升。的確,沒(méi)有真正解決過(guò)無(wú)數(shù)的bug或問(wèn)題的程序員,談不上專家,談不上高級(jí)程序員。而一個(gè)高級(jí)程序員正是從這種解決問(wèn)題的過(guò)程中不斷地歷練自己,形成一套爛熟于心的問(wèn)題解決思路,讓自己強(qiáng)大的。
我也簡(jiǎn)單說(shuō)說(shuō)PHP程序員成長(zhǎng)過(guò)程中經(jīng)常遇到的一些問(wèn)題,如果你一個(gè)也沒(méi)遇到或很少遇到,那么您就是兩個(gè)極端的人:要么初級(jí)入門,要么高級(jí)了,哈哈。
1、編碼問(wèn)題。
2、PHP和SQL數(shù)據(jù)庫(kù)執(zhí)行效率問(wèn)題。
3、Session和Cookie域和加密解析問(wèn)題。
4、程序的執(zhí)行順序問(wèn)題。
5、程序編寫的多環(huán)境適用問(wèn)題。
6、分類的構(gòu)建和結(jié)構(gòu)設(shè)計(jì)問(wèn)題。
7、字符串處理問(wèn)題:正則表達(dá)式處理或簡(jiǎn)單PHP字符串處理函數(shù)來(lái)處理。
8、各種模板引擎的編寫局限性問(wèn)題。
9、PHP和web端數(shù)據(jù)交互問(wèn)題(如ajax,接口調(diào)用等)。
三、過(guò)硬的PHP基礎(chǔ)知識(shí)
沒(méi)有過(guò)硬的PHP基礎(chǔ)知識(shí),哪怕心態(tài)再好,問(wèn)題解決的能力再?gòu)?qiáng),也只能紙上談兵。
過(guò)硬的基礎(chǔ)知識(shí)會(huì)讓你在項(xiàng)目開(kāi)發(fā)過(guò)程中游刃有余。
我也簡(jiǎn)單說(shuō)說(shuō)哪些屬于PHP工程師所應(yīng)具備的基礎(chǔ)知識(shí)(其實(shí)這些在招聘需求中很常見(jiàn)):
1、語(yǔ)法規(guī)則,這個(gè)不說(shuō)了,這個(gè)不會(huì),就沒(méi)入門,趕緊買本書或找個(gè)網(wǎng)站補(bǔ)補(bǔ)。
2、MYSQL各種sql語(yǔ)句的寫法,增刪改查基本的不說(shuō)了,in(),union,left(),left join,as,replace,alter table,where的字段排序,各種索引建立的方法要特別熟悉。
3、會(huì)自己搭建LAMP環(huán)境和WAMP環(huán)境,用集成軟件一鍵式安裝的不算。開(kāi)發(fā)程序,對(duì)于自己開(kāi)發(fā)的環(huán)境構(gòu)建結(jié)構(gòu)都不清楚,怎么排查問(wèn)題?所以至少要會(huì)用對(duì)立的msi文件來(lái)安裝自己需要的開(kāi)發(fā)環(huán)境。安裝3-5遍成功,這個(gè)算還行,還得會(huì)安裝各種擴(kuò)展,配置apache服務(wù),知道各種參數(shù)設(shè)置的地方以及知道怎么設(shè)置各種參數(shù);會(huì)linux操作系統(tǒng)的基本命令。
4、熟悉web方面的其他程序,因?yàn)镻HP不是一個(gè)完全獨(dú)立的東西,他是一個(gè)和其他語(yǔ)言和要素配合來(lái)完成一個(gè)項(xiàng)目的,如果對(duì)其他語(yǔ)言和要素不太熟悉,在團(tuán)隊(duì)協(xié)作過(guò)程中會(huì)非常吃力。這些其他要素包括:html,javascript,jquery,xml,http協(xié)議,正則表達(dá)式等。
四、綜合的互聯(lián)網(wǎng)應(yīng)用及項(xiàng)目管理知識(shí)和素養(yǎng)
1、見(jiàn)識(shí)廣博,擅于學(xué)習(xí)
只顧自己鉆研,不看看、學(xué)學(xué)人家的做法,會(huì)像井底之蛙,難以看到廣闊的天空的;所以,不要只顧著天天編程,學(xué)會(huì)抽點(diǎn)時(shí)間去看看一些大型開(kāi)源系統(tǒng)的架構(gòu)思路,以及大型商務(wù)網(wǎng)站的構(gòu)建方式。向他們學(xué)習(xí),補(bǔ)充自己的不足。
比如至少該曉得不同類型的開(kāi)源系統(tǒng)有哪些吧,比如Uchome,dede,phpcms,wordpress,discuz,帝國(guó)等等。
看多了,你也會(huì)總結(jié)發(fā)現(xiàn)一些常規(guī)性的思路,比如緩存的機(jī)制,比如模板機(jī)制,比如靜態(tài)頁(yè)面生成等等。
2、項(xiàng)目解決方案選型
不同需求,用不同的機(jī)構(gòu)和選型。也就是常說(shuō)的“水來(lái)土掩,兵來(lái)將擋”,有些架構(gòu)固然強(qiáng)大,但是用于小型項(xiàng)目也會(huì)很吃力,就是殺機(jī)不用牛刀。根據(jù)需求來(lái)選型很重要。
選型不是隨口就能定的,需要一個(gè)PHP程序員用于良好的儲(chǔ)備,個(gè)人覺(jué)得至少需要以下儲(chǔ)備,才具備選型能力:
熟練應(yīng)用至少一個(gè)PHP框架,兩-三個(gè)PHP開(kāi)源系統(tǒng);
擁有自己的一套應(yīng)用系統(tǒng)。
3、良好的項(xiàng)目管理素養(yǎng)
項(xiàng)目不是一直開(kāi)發(fā)過(guò)程中,項(xiàng)目也會(huì)進(jìn)入運(yùn)營(yíng)期,維護(hù)期,這樣,具備良好的項(xiàng)目管理素養(yǎng)會(huì)使項(xiàng)目更加穩(wěn)定,可控。
良好的項(xiàng)目管理素養(yǎng)包括:
良好的項(xiàng)目開(kāi)發(fā)及維護(hù)習(xí)慣,記住:千萬(wàn)別為了一時(shí)的省力,造成后面多次的重復(fù)勞動(dòng)。時(shí)時(shí)提醒自己將工作流程化,流程規(guī)劃化,規(guī)范簡(jiǎn)單化。
良好的多人合作管理意識(shí):項(xiàng)目不是一個(gè)人的,是多人協(xié)作的產(chǎn)物,也是服務(wù)于大眾的,因而,要提升協(xié)作意識(shí),讓相關(guān)人員一同來(lái)完善項(xiàng)目。
4、豐富的項(xiàng)目開(kāi)發(fā)應(yīng)用經(jīng)驗(yàn)
學(xué)理論,去考試或考核是學(xué)校里面的事兒,沒(méi)有項(xiàng)目經(jīng)驗(yàn),就像滿肚子經(jīng)文,吐也難吐出。
這就需要實(shí)際的項(xiàng)目將自己的知識(shí)去學(xué)會(huì)轉(zhuǎn)化為需求實(shí)現(xiàn)。
5、良好的開(kāi)發(fā)規(guī)范
代碼可讀性強(qiáng):對(duì)象,方法,函數(shù)的注釋;一套成熟的命名規(guī)范。
代碼冗余度底:程序和文件的重用性大,高內(nèi)聚,低耦合。
執(zhí)行效率高:用最簡(jiǎn)單的程序流程實(shí)現(xiàn)應(yīng)用需求,勿擾大彎子。
代碼安全性好:做一名警惕的程序員,任何有用戶輸入和上傳文件的地方都得額外謹(jǐn)慎,也許一個(gè)程序員一時(shí)的疏忽就會(huì)導(dǎo)致一個(gè)系統(tǒng)頃刻間崩潰。
另外,多說(shuō)幾句,PHP高級(jí)工程師,其實(shí)對(duì)于一個(gè)稍微能堅(jiān)持,并喜歡PHP的來(lái)說(shuō)不太難;難的是學(xué)會(huì)用工具來(lái)實(shí)現(xiàn)想法,不管是自己的想法還是他人的需求,學(xué)會(huì)轉(zhuǎn)化。