周昕
這是最常見的內(nèi)連接查詢 select a.fielda, b.fieldb from a, b where a.id=b.id : 但問題是,popt,poval,pa這些都是 數(shù)據(jù)庫 中沒有的表啊 回答: popt, poval, pa是別名 例如這一句: select a.fielda, b.fieldb from asdf a, bvcx b where a.id=b.id a是 asdf 的別名, b 是bvcx 的別名. : 可是別名是怎么獲取或者說怎么定義的 回答: 由用戶自定義. 例如你想叫某人的 外號(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]可以省略 : 請問下,用別名進(jìn)行操作,有什么好處嗎? 回答: 短 : 就這樣啊... 回答: 呃..還有可以避免重復(fù)的名字出現(xiàn) 例如 select a.* from asdf a, asdf b where a.parent = b.parent and a.id=123 補(bǔ)充: 上例如果不使用別名就無法寫where 子句 了
朱權(quán)
建議樓主看看這個(gè) PHP程序員的分類http://bbs.php100.com/read-htm-tid-18707.html
萬載寒蚿
我是初學(xué)者,但是我可以給你推薦一個(gè)網(wǎng)站www.php100.com里面有視頻教程,也有比較深入的高級編程討論,你不妨去看一看。
參考資料:www.php100.com
加賀正午
一個(gè)普通的PHP程序員,除了PHP本身的知識(shí)外,需要數(shù)據(jù)庫的基本知識(shí)。 一個(gè)PHP高級程序員要掌握的知識(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語言非常接近,逐漸學(xué)習(xí),由易到難。做出一個(gè)象樣的東西大概快一點(diǎn)的三個(gè)月,慢一點(diǎn)的半年吧。
朱果
php基礎(chǔ)要會(huì),基本語法,面向?qū)ο螅瑪?shù)據(jù)庫設(shè)計(jì)對mvc框架熟悉例如 thinkphp,yii,Ci等拿thinkphp為例。假如你對thinkphp框架很熟悉了,并且能熟練應(yīng)用了,然后仿照thinkphp框架 自己寫一個(gè)mvc框架沒有必要寫的像thinkphp功能那么全,只要把核心功能寫出來了就行了這個(gè)時(shí)候你會(huì)發(fā)現(xiàn)你的php水平會(huì)有很大的提高,差不多就達(dá)到了高級程序員了
閔一得
我也是PHPer,但是具體怎么劃分我也不太清除,按照我個(gè)人的理解是:初級:熟練搭建PHP環(huán)境,熟悉PHP函數(shù),會(huì)寫函數(shù),寫簡單的類!中級:熟悉使用模版引擎,比如smarty!熟悉Linux開發(fā)環(huán)境,能使用框架開發(fā),比如zend的!高級:可能就是框架結(jié)構(gòu)方面的了吧!
嚴(yán)綱
高級php工程師可以往幾個(gè)方向去發(fā)展:1.深度方向一個(gè)工程師要往高階發(fā)展,必須同時(shí)強(qiáng)化幾個(gè)技術(shù)能力:設(shè)計(jì)能力:懂得如何利用分層、面向?qū)ο?、設(shè)計(jì)模式等設(shè)計(jì)組織代碼編碼能力:熟悉php語法特性,知道怎么用一兩行代碼代替初級開發(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é)。抽象能力:初級開發(fā)者通常會(huì)等到邏輯重復(fù)時(shí)再抽象封裝(甚至怕拖進(jìn)度或者懶惰而放棄),而高級開發(fā)者通常一開始寫出的邏輯就為了以后的重用,并且深知一開始多付出的思考設(shè)計(jì)時(shí)間最終都會(huì)因?yàn)閺?fù)用得到回報(bào)。很多開發(fā)框架就是一步步抽象/埋坑/優(yōu)化而來的。架構(gòu)能力:一個(gè)業(yè)務(wù)系統(tǒng)如何劃分模塊,模塊之間如何協(xié)作通信,每個(gè)模塊的技術(shù)選型如何做,系統(tǒng)細(xì)節(jié)如何規(guī)避問題等等。優(yōu)化能力:學(xué)會(huì)如何評估、分析、提升系統(tǒng)性能。優(yōu)化途徑很多,產(chǎn)品功能優(yōu)化、業(yè)務(wù)邏輯優(yōu)化、基礎(chǔ)技術(shù)優(yōu)化、操作系統(tǒng)底層硬件的優(yōu)化等等。2.廣度方向php開發(fā)基本上離不開操作系統(tǒng)、存儲(chǔ)、緩存、網(wǎng)絡(luò)、webserver等等配套設(shè)施,因此這也是高階必備技能。一旦業(yè)務(wù)系統(tǒng)出問題了,必須要能快速定位解決(不一定自己解決,但要知道找到哪個(gè)負(fù)責(zé)人來解決)。比如存儲(chǔ)mysql,高級開發(fā)者會(huì)懂得利用索引、利用分表分庫提高查詢性能,懂得負(fù)載均衡和災(zāi)備提高性能提高可靠性(雖然是DBA的工作,但了解了有助于出問題時(shí)排查)比如緩存,高級開發(fā)者懂得如何有效且最大限度利用緩存系統(tǒng)提高應(yīng)用性能。比如http,初級開發(fā)者往往只懂得http網(wǎng)絡(luò)請求就只一去一回兩個(gè)包,高級開發(fā)者會(huì)去深究網(wǎng)絡(luò)七層模型、會(huì)深究http請求的各個(gè)環(huán)節(jié)(DNS、三次握手等等)比如web前端,學(xué)習(xí)如何依靠瀏覽器緩存、CDN緩存、壓縮代碼、合并文件等等提高前端性能,學(xué)習(xí)如何進(jìn)行前端安全攻防。3,軟素質(zhì)懂得團(tuán)隊(duì)管理,項(xiàng)目管理,溝通技巧等等。
馬千矚
PHP 工程師 (PHP Programmar) 定義: 正在以PHP程序?yàn)橹饕ぷ?并正在進(jìn)行新產(chǎn)品的研發(fā).可以同時(shí)使用C+/perl等輔助提高PHP程序性能的人是PHP工程師. 描述: PHP工程師是. 特征: 1: 精通一種或多種linux. 2: 快速編寫結(jié)構(gòu)清晰,代碼格式優(yōu)美的PHP程序. 3: 能夠進(jìn)行框架級通用程序的研發(fā). 4: 能夠在程序開發(fā)初期就通過項(xiàng)目規(guī)劃避免未來可能出現(xiàn)的性能瓶頸. 5: 能夠使用框架/類庫加速項(xiàng)目開發(fā)進(jìn)度. 6: 有自己的代碼庫. 7: 能夠勝任大部分服務(wù)器和部分服務(wù)器集群優(yōu)化工作. 技術(shù)要求我就不說了.具體到PHP中級程序員之后,PHP程序員就開始選擇發(fā)展方向進(jìn)行分化了.能夠到這一步的人,基本都對自己的職業(yè)規(guī)劃有清晰的認(rèn)識(shí).目前國內(nèi)此類人才奇少.關(guān)于其他: 1 PHP程序員從中級程序員階段就開始分化,具體方向根據(jù)公司性質(zhì),工作條件,自己的興趣等不一而同.因此需要擅長的詳細(xì)技能也不太相同. 例如: 公司使用 joomla 構(gòu)建網(wǎng)站, 這就要求程序員必須精通joomla. 如果公司使用自研CMS+discuz構(gòu)建網(wǎng)站,這就要求程序員能夠熟練進(jìn)行DISCUZ的二次開發(fā).強(qiáng)行要求程序員精通這精通那,意義不大. 到高級程序員開始.PHP程序員由于自己的職業(yè)經(jīng)歷.肯定會(huì)有自己的專攻方向,有人擅長大負(fù)載下程序開發(fā)優(yōu)化,有人擅長項(xiàng)目快速開發(fā).而到這個(gè)階段,如果PHP程序員還需要看這篇文章規(guī)劃自己的職業(yè)生涯.那么請自己列出自己擅長的PHP技術(shù).并選擇一種最擅長的技術(shù)專攻. 2 關(guān)于coder和programmar. 字面上理解第一個(gè)是編碼員,第二個(gè)是程序員.實(shí)際因?yàn)閲鴥?nèi)名詞的混亂.第一個(gè)大多以程序員稱呼,第二個(gè)目前大多處于項(xiàng)目核心領(lǐng)導(dǎo)層面.故本文暫以工程師稱呼. coder 是進(jìn)行少量創(chuàng)新的,大量重復(fù)工作的人. programmar 是進(jìn)行新技術(shù)摸索開發(fā),并實(shí)際領(lǐng)導(dǎo)/帶領(lǐng)大中型項(xiàng)目開發(fā)的人. 3 關(guān)于 C++ . PHP初期的語法(php3/4時(shí)代)和C幾乎一樣.我當(dāng)初就是看一下午PHP速成+php手冊入的門.但到一定深度之后.有些PHP的特性需要實(shí)際閱讀PHP源碼才能理解(相關(guān)文檔不全或者不好找到).有些實(shí)際項(xiàng)目功能使用C++開發(fā)遠(yuǎn)比PHP效率高.比如我現(xiàn)在做的項(xiàng)目需要爬蟲持續(xù)海量抓取,當(dāng)帶寬足夠的情況時(shí),純使用PHP實(shí)現(xiàn)效率不高.所以必須使用C++. 所以C++到需要用的時(shí)候自然而然的就要用了.不過如果有C/C++的基礎(chǔ),學(xué)習(xí)PHP要輕松很多. 4 關(guān)于面向?qū)ο?面向?qū)ο筮€是很帥的,小型工程上使用意義不大,大中型工程可以極大的提升開發(fā)效率.在php4的時(shí)代對面向?qū)ο蠡緵]有什么要求,但是現(xiàn)在需要完整掌握面向?qū)ο? 5 關(guān)于JAVA/Delphi 他們和php有關(guān)么? 我孤陋寡聞.請牛人指教.謝謝 6 關(guān)于軟件工程. 軟件工程是一個(gè)實(shí)際使用中才能學(xué)懂的學(xué)科.我才疏學(xué)淺,在大學(xué)的時(shí)候楞沒學(xué)懂.等實(shí)際領(lǐng)導(dǎo)項(xiàng)目了.才慢慢的明白其中的含義與奧妙. 8 關(guān)于開發(fā)模式. 開發(fā)模式的好壞直接關(guān)系這項(xiàng)目開發(fā)的速度與項(xiàng)目的質(zhì)量.初期死摳模式意義不大.建議有一定積累了再說. 9 關(guān)于名氣. 嗯...怎么說呢?高端PHP圈子很小,也就那么些人.水平到了,自然就認(rèn)識(shí)那些人了. 10 關(guān)于第三方庫,初期學(xué)習(xí)掌握一些,比如smarty.到一定階段需要決定到底是精通第三方庫還是使用自行積累開發(fā)的庫.總的來說,由于第三方庫大多是外國人開發(fā),所以國內(nèi)想要時(shí)刻緊跟比較被動(dòng),phpBB中文的沒落便是一例.如果使用自行積累開發(fā)的庫,難度較大,要注意通用性和可擴(kuò)展性. 11 關(guān)于英文. 這個(gè)是廢話.最低要求是流暢閱讀英文文檔.
參考資料:http://bbs.chinaunix.net/viewthread.php?tid=1023017
煉魔神針
1.掌握語言本身的語法,熟悉常用類庫是必須的; 2.面向?qū)ο笞顬楫?dāng)今的主流也是必須掌握的; 3.常用設(shè)計(jì)模式必須掌握,設(shè)計(jì)模式是前輩的總結(jié)、經(jīng)驗(yàn); 4.php常與數(shù)據(jù)庫配合使用,而且首先為mysql,所以mysql必須熟悉; 5.php是做為一種web開發(fā)語言而流行的,所以瀏覽器中的javascript必須會(huì),雖然現(xiàn)在很多公司有專業(yè)的javascript工程師,但是php程序員js也是必須掌握的; 6.html/css必須會(huì),不要求你會(huì)切會(huì)div+css,但是至少要知道,因?yàn)閜hp是一種嵌入html中使用的語言(當(dāng)然php也可以用于桌面等其他,但是和web(html)結(jié)合才是它流行的原因); 7.linux不需要會(huì),會(huì)的話肯定更好,一般公司都有專門服務(wù)器管理人員的。但是你要會(huì)在vi下進(jìn)行編程,這時(shí)候就不像在ide下那么好了,你應(yīng)該盡量熟悉類庫。