第一篇:PHP初級程序員應該掌握的知識
PHP初級程序員應該掌握的知識
很多PHP初學者不知道該怎么學好它,不知道從何下手,這里分享的PHP初級程序員應該掌握的知識,幫助你理清思路,為未來的學習鋪好路。
1.Linux:
基本命令、操作、啟動、基本服務配置(包括rpm安裝文件,各種服務配置等);會寫簡單的shell腳本和awk/sed 腳本命令等。
2.Nginx:
做到能夠安裝配置nginx+php,知道基本的nginx核心配置選項,知道 server/fastcgi_pass/access_log 等基礎配置,目標是能夠讓nginx+php_fpm順利工作。
3.MySQL:
會自己搭建mysql,知道基本的mysql配置選項;知道innodb和myisam的區別,知道針對InnoDB和MyISAM兩個引擎的不同 配置選項;知道基本的兩個引擎的差異和選擇上面的區別;能夠純手工編譯搭建一個MySQL數據庫并且配置好編碼等正常穩定運行;核心主旨是能夠搭建一個可 運行的MySQL數據庫。
4.PHP:
基本語法數組、字符串、數據庫、XML、Socket、GD/ImageMgk圖片處理等等;熟悉各種跟MySQL操作鏈接的api(mysql /mysqli/PDO),知道各種編碼問題的解決;知道常規熟練使用的PHP框架(ThinkPHP、Zendframework、Yii、Yaf 等);了解基本MVC的運行機制和為什么這么做,稍微知道不同的PHP框架之間的區別;能夠快速學習一個MVC框架。能夠知道開發工程中的文件目錄組織,有基本的良好的代碼結構和風格,能夠完成小系統的開發和中型系統中某個模塊的開發工作。
5.前端:
如果條件時間允許,可以適當學習下 HTML/CSS/JS 等相關知識,知道什么web標準,p+css的web/wap頁面模式,知道 HTML5和HTML4的區別;了解一些基本的前端只是和JS框架(jQuery之類的);了解一些基本的JavaScript編程知識;(本項不是必須 項,如果有時間,稍微了解一下是可以的,不過不建議作為重點,除非個人有強烈興趣)
6.系統設計:
能夠完成小型系統的基本設計,包括簡單的數據庫設計,能夠完成基本的:瀏覽器-> Nginx+PHP-> 數據庫 架構的設計開發工作;能夠支撐每天幾十萬到數百萬流量網站的開發維護工作。
北大青鳥蘭州校區與上百家IT知名企業簽訂用人協議,學員入學即可簽訂就業協議,就業方面全方位保障學員更好的就業。畢業時,學員可以獲得全國免費推薦工作。
更多有關學習IT的問題,請點擊咨詢。
第二篇:PHP程序員應該掌握的10項技能!
一個PHP程序員應該掌握的10項技能!
很多學PHP的人一直也搞不清楚,一個PHP程序員和Java程序員或者是.net程序員有什么不同,告訴你,其實都一樣!沒有什么不同,下面的內容,就是針對一個Java程序員掌握的技能對比PHP來說的!告訴你,它們其實是一樣的,不過是工具而已,沒有高低貴賤之分。只不過你不熟練,不知道而已!
1、語法:必須比較熟悉,在寫代碼的時候IDE的編輯器對某一行報錯應該能夠根據報錯信息知道是什么樣的語法錯誤并且知道任何修正。
2、命令:必須熟悉PHP帶的一些常用命令及其常用選項,熟悉那些命令,自己運行php.exe-h 如果這些命令你沒有全部使用過,那么你對PHP實際上還很不了解。
3、工具:必須至少熟練使用一種IDE的開發工具,例如:Eclipse、Netbeans、zend或者editplus,ultraedit,包括進行工程管理、常用選項的設置、PHP插件的安裝配置以及進行調試。
4、API:PHP的核心API是非常龐大的,但是有一些內容筆者認為是必須熟悉的,否則不可能熟練的運用PHP,包括:
◆ 文件目錄處理函數包80%以上的函數的功能的靈活運用。
◆ 日期時間函數中的80%以上的函數的功能的靈活運用
◆ 數學函數庫中的100%的內容。
◆ 網絡庫中的60%以上的內容,對各個函數的功能比較熟悉。
◆ 字符串處理函數下的60%以上的內容,特別是各種處理函數。
◆ 正則表達式函數下的90%以上的內容,特別是各種正則處理
◆ 一些安全庫下的40%以上的內容,如果對于安全沒有接觸的話根本就不可能掌握PHP
◆ XML處理,熟悉SAX、DOM以及JDOM的優缺點并且能夠使用其中的一種完成XML的解析及內容處理。
◆ 圖形圖像函數庫下的80%以上的內容,特別是一些圖像生成和處理
◆ MySQL 數據庫函數下的90%以上的內容,特別是處理各種數據的函數
◆ 數組處理函數下的90%以上的內容,特別是各種操作處理函數
◆ 其它PEAR,PECL,和一些擴展類庫中的80%以上的內容,特別是一些常用的類的處理
◆ 針對不同的需求,查找不同的函數庫。
5、測試:必須熟悉使用phpunit編寫測試用例完成代碼的自動測試。
6、管理:必須熟悉使用xinc, phing等完成工程管理的常用任務,例如工程編譯、生成phpdoc、生成、版本控制、自動測試。
7、排錯:應該可以根據異常信息比較快速的定位問題的原因和大致位置。
8、思想:必須掌握OOP的主要要求,這樣使用PHP開發的系統才能是真正的PHP系統。
9、規范:編寫的代碼必須符合流行的編碼規范,這樣程序的可讀性才比較好。
10、博學:掌握OOA、OOD、MS SQL Server、Oracle、Zendframework、cakephp、symfony、模板技術等流行技術,掌握軟件架構設計思想、搜索引擎優化、緩存系統設計、網站負載均衡、系統性能調優等實用技術。
綜合上述,沒發現PHP和java有什么不同!PHP和Java,還是.net一樣要學的東西有很多!
推薦格言:
浮躁的人容易說:PHP語言不行,應該學Java,C#,VB.NET:--是你自己不行了吧!?
浮躁的人容易問:PHP和Java,C#,VB.NET哪個好;--告訴你吧,都好--只要你學好就行;
浮躁的人容易問:我到底該學什么:--別問,學就對了;
浮躁的人容易問:PHP有錢途嗎:--建議你去強銀行
專家建議:
如果可選的語言有好幾種,那么,選擇其中學習難度最小的一種。
不要輕信廣告,不要輕信媒體。唯一可以相信的是你的市場。
個人可以喜歡一種、兩種甚至好幾種語言,但一定不要排斥其他任何一種語言
第三篇:中高級PHP程序員應該掌握哪些技術[最終版]
網站建設定制專家www.tmdps.cn
中高級PHP程序員應該掌握哪些技術? 中級PHP程序員
1.Linux 能夠流暢的使用Shell腳本來完成很多自動化的工作;awk/sed/perl 也操作的不錯,能夠完成很多文本處理和數據統計等工作;基本能夠安裝大 部分非特殊的Linux程序(包括各種庫、包、第三方依賴等等,比如MongoDB/Redis/Sphinx/Luncene/SVN之類的);了解基 本的Linux服務,知道如何查看Linux的性能指標數據,知道基本的Linux下面的問題跟蹤等
2.Nginx:
在第一階段的基礎上面,了解復雜一些的Nginx配置;包括多核配置、events、proxy_pass,sendfile/tcp_*配置,知道超 時等相關配置和性能影響;知道nginx除了web server,還能夠承擔代理服務器、反向靜態服務器等配置;知道基本的nginx配置調優;知道如 何配置權限、編譯一個nginx擴展到nginx;知道基本的nginx運行原理(master/worker機制,epoll),知道為什么nginx 性能比apache性能好等知識;
3.MySQL/MongoDB:
在第一階段的基礎上面,在MySQL開發方面,掌握很多小技巧,包括常規SQL優化(group by/order by/rand優化等);除了能夠搭 建MySQL,還能夠冷熱備份MySQL數據,還知道影響innodb/myisam性能的配置選項(比如key_buffer/query_cache /sort_buffer/innodb_buffer_pool_size/innodb_flush_log_at_trx_commit等),也知 道這些選項配置成為多少值合適;另外也了解一些特殊的配置選項,比如 知道如何搭建mysql主從同步的環境,知道各個binlog_format的區 別;知道MySQL的性能追查,包括slow_log/explain等,還能夠知道基本的索引建立處理等知識;原理方面了解基本的MySQL的架構(Server+存儲引擎),知道基本的InnoDB/MyISAM索引存儲結構和不同(聚簇索引,B樹);知道基本的InnoDB事務處理機制;了解大 部分MySQL異常情況的處理方案(或者知道哪兒找到處理方案)。條件允許的情況,建議了解一下NoSQL的代表MongoDB數據庫,順便對比跟 MySQL的差別,同事能夠在合適的應用場景安全謹慎的使用MongoDB,知道基本的PHP與MongoDB的結合開發。
4.Redis/Memcached:
在大部分中型系統里面一定會涉及到緩存處理,所以一定要了解基本的緩存;知道Memcached和Redis的異同和應用場景,能夠獨立安 裝 Redis/Memcached,了解Memcahed的一些基本特性和限制,比如最大的value值,知道PHP跟他們的使用結合;Redis了解 基本工作原理和使用,了解常規的數據類型,知道什么場景應用什么類型,了解Redis的事務等等。原理部分,能夠大概了解Memcached的內存結構(slab機制),redis就了解常用數據類型底層實現存儲結構(SDS/鏈表/SkipList/HashTable)等等,順便了解一下Redis 的事務、RDB、AOF等機制更好 網站建設定制專家www.tmdps.cn
5.PHP:
除了第一階段的能力,安裝配置方面能夠隨意安裝PHP和各種第三方擴展的編譯安裝配置;了解php-fpm的大部分配置選項和含義(如 max_requests/max_children/request_terminate_timeout之類的影響性能的配置),知道mod_php /fastcgi的區別;在PHP方面已經能夠熟練各種基礎技術,還包括各種深入些的PHP,包括對PHP面向對象的深入理解/SPL/語法層面的特殊特 性比如反射之類的;在框架方面已經閱讀過最少一個以上常規PHP MVC框架的代碼了,知道基本PHP框架內部實現機制和設計思想;在PHP開發中已經能 夠熟練使用常規的設計模式來應用開發(抽象工廠/單例/觀察者/命令鏈/策略/適配器 等模式);建議開發自己的PHP MVC框架來充分讓開發自由化,讓自己深入理解MVC模式,也讓自己能夠在業務項目開發里快速升級;熟悉PHP的各種代碼優化方法,熟悉大部分PHP安全方面問題的解決處理;熟悉基本的 PHP執行的機制原理(Zend引擎/擴展基本工作機制);
6.系統設計:
能夠設計大部分中型系統的網站架構、數據庫、基本PHP框架選型;性能測試排查處理等;能夠完成類似:瀏覽 器-> CDN(Squid)-> Nginx+PHP-> 緩存-> 數據庫 結構網站的基本設計開發維護;能夠支撐 每天數百萬到千萬流量基本網站的開發維護工作;
高級PHP程序員
重點:除了基本的LNMP程序,還能夠在某個方向或領域有深入學習。(縱深維度發展)
目標:除了能夠完成基本的PHP業務開發,還能夠解決大部分深入復雜的技術問題,并且可以獨立設計完成中大型的系統設計和開發工作;自己能夠獨立hold深入某個技術方向,在這塊比較專業。(比如在MySQL、Nginx、PHP、Redis等等任一方向深入研究)
1.Linux:
除了第二階段的能力,在Linux下面除了常規的操作和性能監控跟蹤,還能夠使用很多高級復雜的命令完成工作(watch/tcpdump/starce /ldd/ar等);在shell腳本方面,已經能夠編寫比較復雜的shell腳本(超過500行)來協助完成很多包括備份、自動化處理、監控等工作的 shell;對awk/sed/perl 等應用已經如火純青,能夠隨意操作控制處理文本統計分析各種復雜格式的數據;對Linux內部機制有一些了解,對內核模塊加載,啟動錯誤處理等等有個基本的處理;同時對一些其他相關的東西也了解,比如NFS、磁盤管理等等;
2.Nginx:
在第二階段的基礎上面,已經能夠把Nginx操作的很熟練,能夠對Nginx進行更深入的運維工作,比如監控、性能優化,復雜問題處理等等;看個人興趣,更多方面可以考慮側重在關于Nginx工作原理部分的深入學習,主要表現在閱讀源碼開始,比如具體的master/worker工作機制,Nginx內部 的事件處理,內存管理等等;同時可以學習Nginx擴展的開發,可以定制一些自己私有的擴展;同時可以對Nginx+Lua有一定程度的了解,看看網站建設定制專家www.tmdps.cn
是否可 以結合應用出更好模式;這個階段的要求是對Nginx原理的深入理解,可以考慮成為Nginx方向的深入專業者。
3.MySQL/MongoDB:
在第二階段的基礎上面,在MySQL應用方面,除了之前的基本SQL優化,還能夠在完成一些復雜操作,比如大批量數據的導入導出,線上大批量數據的更改表 結構或者增刪索引字段等等高危操作;除了安裝配置,已經能夠處理更多復雜的MySQL的問題,比如各種問題的追查,主從同步延遲問題的解決、跨機房同步數 據方案、MySQL高可用架構等都有涉及了解;對MySQL應用層面,對MySQL的核心關鍵技術比較熟悉,比如事務機制(隔離級別、鎖等)、對觸發器、分區等技術有一定了解和應用;對MySQL性能方面,有包括磁盤優化(SAS遷移到SSD)、服務器優化(內存、服務器本身配置)、除了二階段的其他核心 性能優化選項(innodb_log_buffer_size/back_log/table_open_cache /thread_cache_size/innodb_lock_wait_timeout等)、連接池軟件選擇應用,對show *(show status/show profile)類的操作語句有深入了解,能夠完成大部分的性能問題追查;MySQL備份技術的深入熟悉,包括災備 還原、對Binlog的深入理解,冷熱備份,多IDC備份等;在MySQL原理方面,有更多了解,比如對MySQL的工作機制開始閱讀部分源碼,比如對主 從同步(復制)技術的源碼學習,或者對某個存儲引擎(MyISAM/Innodb/TokuDB)等等的源碼學習理解,如果條件允許,可以參考CSV引擎 開發自己簡單的存儲引擎來保存一些數據,增強對MySQL的理解;在這個過程,如果自己有興趣,也可以考慮往DBA方向發展。MongoDB層面,可以考 慮比如說在寫少讀多的情況開始在線上應用MongoDB,或者是做一些線上的數據分析處理的操作,具體場景可以按照工作來,不過核心是要更好的深入理解 RMDBS和NoSQL的不同場景下面的應用,如果條件或者興趣允許,可以開始深入學習一下MongoDB的工作機制。
4.Redis/Memcached:
在第二階段的基礎上面,能夠更深入的應用和學習。因為Memcached不是特別復雜,建議可以把源碼進行閱讀,特別是內存管理部分,方便深入理 解;Redis部分,可以多做一些復雜的數據結構的應用(zset來做排行榜排序操作/事務處理用來保證原子性在秒殺類場景應用之類的使用操作);多涉及 aof等同步機制的學習應用,設計一個高可用的Redis應用架構和集群;建議可以深入的學習一下Redis的源碼,把在第二階段積累的知識都可以應用 上,特別可以閱讀一下包括核心事件管理、內存管理、內部核心數據結構等充分學習了解一下。如果興趣允許,可以成為一個Redis方面非常專業的使用者。
5.PHP:
作為基礎核心技能,我們在第二階段的基礎上面,需要有更深入的學習和應用。從基本代碼應用上面來說,能夠解決在PHP開發中遇到95%的問題,了解大部分 PHP的技巧;對大部分的PHP框架能夠迅速在一天內上手使用,并且了解各個主流PHP框架的優缺點,能夠迅速方便項目開發中做技術選型;在配置方面,除 了常規第二階段會的知識,會了解一些比較偏門的配置選項(php auto_prepend_file/auto_append_file),包括擴展中 的一些復雜高級配置和原理(比如memcached擴展配置中的memcache.hash_strategy、apc擴展配置中的 apc.mmap_file_mask/apc.slam_defense/apc.file_update_protection之類的);對php的 工網站建設定制專家www.tmdps.cn
作機制比較了解,包括php-fpm工作機制(比如php-fpm在不同配置機器下面開啟進程數量計算以及原理),對zend引擎有基本熟悉(vm/gc/stream處理),閱讀過基本的PHP內核源碼(或者閱讀過相關文章),對PHP內部機制的大部分核心數據結構(基礎類型/Array /Object)實現有了解,對于核心基礎結構(zval/hashtable/gc)有深入學習了解;能夠進行基本的PHP擴展開發,了解一些擴展開發 的中高級知識(minit/rinit等),熟悉php跟apache/nginx不同的通信交互方式細節(mod_php/fastcgi);除了開發 PHP擴展,可以考慮學習開發Zend擴展,從更底層去了解PHP。
6.C/C++:
在第二階段基礎上面,能夠在C/C++語言方面有更深入的學習了解,能夠完成中小型C/C++系統的開發工作;除了基本第二階段的基礎C/C++語法和數 據結構,也能夠學習一些特殊數據結構(b-tree/rb-tree/skiplist/lsm-tree/trie-tree等)方便在特殊工作中需 求;在系統編程方面,熟悉多進程、多線程編程;多進程情況下面了解大部分多進程之間的通信方式,能夠靈活選擇通信方式(共享內存/信號量/管道等);多線 程編程能夠良好的解決鎖沖突問題,并且能夠進行多線程程序的開發調試工作;同時對網絡編程比較熟悉,了解多進程模型/多線程模型/異步網絡IO模型的差別 和選型,熟悉不同異步網絡IO模型的原理和差異(select/poll/epoll/iocp等),并且熟悉常見的異步框架(ACE/ICE /libev/libevent/libuv/Boost.ASIO等)和使用,如果閑暇也可以看看一些國產自己開發的庫(比如muduo);同時能夠設 計好的高并發程序架構(leader-follow/master-worker等);了解大部分C/C++后端Server開發中的問題(內存管理、日 志打印、高并發、前后端通信協議、服務監控),知道各個后端服務RPC通信問題(struct/http/thirft/protobuf等);能夠更熟 絡的使用GCC和GDB來開發編譯調試程序,在線上程序core掉后能夠迅速追查跟蹤解決問題;通用模塊開發方面,可以積累或者開發一些通用的工具或庫(比如異步網絡框架、日志庫、內存池、線程池等),不過開發后是否應用要謹慎,省的埋坑去追bug;
7.前端:
深入了解HTTP協議(包括各個細致協議特殊協議代碼和背后原因,比如302靜態文件緩存了,502是nginx后面php掛了之類的);除了之前的前端 方面的各種框架應用整合能力,前端方面的學習如果有興趣可以更深入,表現形式是,可以自己開發一些類似jQuery的前端框架,或者開發一個富文本編輯器 之類的比較瑣碎考驗JavaScript功力;
8.其他領域語言學習:
在基礎的PHP/C/C++語言方面有基本積累,建議在當前階段可以嘗試學習不同的編程語言,看個人興趣愛好,腳本類語言可以學學 Python /Ruby 之類的,函數式編程語言可以試試 Lisp/Haskell/Scala/Erlang 之類的,靜態語言可以試試 Java /Golang,數據統計分析可以了解了解R語言,如果想換個視角做后端業務,可以試試 Node.js還有前面提到的跟Nginx結合的 Nginx_Lua等。學習不同的語言主要是提升自己的視野和解決問題手段的差異,比如會了解除了進程/線程,還有輕量級協程;比如在跨機器通信場景下 面,Erlang的解決方案簡單的驚人;比如在不想選擇C/C++的情況下,還有類似高效的Erlang/Golang可用等等;主要是提升視野。網站建設定制專家www.tmdps.cn
9.其他專業方向學習:
在本階段里面,會除了基本的LNMP技能之外,會考慮一些其他領域知識的學習,這些都是可以的,看個人興趣和長期的目標方向。目前情況能夠選擇的領域比較 多,比如、云計算(分布式存儲、分布式計算、虛擬機等),機器學習(數據挖掘、模式識別等,應用到統計、個性化推薦),自然語言處理(中文分詞等),搜索 引擎技術、圖形圖像、語音識別等等。除了這些高大上的,也有很多偏工程方面可以學習的地方,比如高性能系統、移動開發(Android/IOS)、計算機 安全、嵌入式系統、硬件等方向。
10.系統設計:
系統設計在第二階段的基礎之上,能夠應用掌握的經驗技能,設計出比較復雜的中大型系統,能夠解決大部分線上的各種復雜系統的問題,完成類似 瀏覽 器-> CDN-> 負載均衡->接入層-> Nginx+PHP-> 業務緩存-> 數據 庫-> 各路復雜后端RPC交互(存儲后端、邏輯后端、反作弊后端、外部服務)-> 更多后端 醬紫的復雜業務;能夠支撐每天數千萬到數 億流量網站的正常開發維護工作。
第四篇:PHP程序員必須掌握的知識
PHP5的優點
PHP5的最大特點是引入了面向對象的全部機制,并且保留了向下的兼容性。程序員不必再編寫缺乏功能性的類,并且能夠以多種方法實現類的保護。另外,在對象的集成等方面也不再存在問題。使用PHP5引進了類型提示和異常處理機制,能更有效的處理和避免錯誤的發生。
mysql_fetch_row,mysql_fetch_array,mysql_fetch_assoc的區別
實例代碼
$link=mysql_connect('localhost','root',”);mysql_select_db('abc',$link);$sql = “select * from book”;
$result = mysql_query($sql);
while($row = mysql_fetch_row($result)){
echo $row['cid'].'::'.$row[1].'
';}
$result = mysql_query($sql);
while($row = mysql_fetch_array($result)){
echo $row['cid'].'::'.$row[1].'
';}
$result = mysql_query($sql);
while($row = mysql_fetch_object($result)){
echo $row->cid.'::'.$row->title.”
”;}
$result = mysql_query($sql);
while($row = mysql_fetch_assoc($result)){
echo $row['cid'].'::'.$row[1].'
';}
?>
詳細解釋:
mysql_fetch_row,這個函數是從結果集中取一行作為枚舉數據,從和指定的結果標識關聯的結果集中取得一行數據并作為數組返回。每個結果的列 儲存在一個數組的單元中,偏移量從 0 開始。注意,這里是從0開始偏移,也就是說不能用字段名字來取值,只能用索引來取值,所以如下代碼是取不到值的:
while($row = mysql_fetch_row($res)){
echo $row['cid'].'::'.$row[1].”;
} //這里的$row['cid'] 取不到值。
mysql_fetch_array,從結果集中取得一行作為關聯數組,或數字數組,或二者兼有,除了將數據以數字索引方式儲存在數組中之外,還可以將數據作為關聯索引儲存,用字段名作為鍵名。也就是說他得到的結果像數組一樣,可以用key或者索引來取值,所以
while($row = mysql_fetch_array($res)){ echo $row['cid'].'::'.$row[1].”;
}//這里$row['cid'],$row[1]都能得到相應的值。
mysql_fetch_object,顧名思義,從結果集中取得一行作為對象,并將字段名字做為屬性。所以只有這樣才能取到值
while($row = mysql_fetch_object($res)){ echo $row->cid.'::'.$row->title.”";
}
mysql_fetch_assoc,從結果集中取得一行作為關聯數組,也就是說這個函數不能像mysql_fetch_row那樣用索引來取值,只能用字段名字來取,所以
while($row = mysql_fetch_assoc($res)){ echo $row['cid'].'::'.$row[1].”;} //$row[1]這樣是取不到值的補充一點:
mysql_fetch_array函數是這樣定義的:array mysql_fetch_array(resource result [, int result_type]),返回根據從結果集取得的行生成的數組,如果沒有更多行則返回 FALSE。
mysql_fetch_array()中可選的第二個參數 result_type 是一個常量,可以接受以下值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。其中:
1、mysql_fetch_assoc($result)==mysql_fetch_array($result,MYSQL_ASSOC);
2、mysql_fetch_row($result)==mysql_fetch_array($result,MYSQL_NUM);
所 以mysql_fetch_array()函數在某種程度上可以算是mysql_fetch_row()與 mysql_fetch_assoc()的集合。另外,mysql_fetch_array()另外還有MYSQL_BOTH參數,將得到一個同時包含關 聯和數字索引的數組。
在來說句 $row = $db->fetch_array($query);
$db是人數據庫操作 類,$db->fetch_array($query),fetch_array($query)是那個db類里的方法,$row = $db->fetch_array($query)這句的意思是從記錄集$query中得到數據庫中的一行記錄。
實例代碼:
$conn=@mysql_connect($host,$user,$pass);@mysql_select_db($database,$conn);$query=mysql_query($sql);
while($row=mysql_fetch_array($query)){ $rows[]=$row;}
索引(詳解)
索引的優點:加快查詢速度。
(如果你總結下索引的用途,其實也就這一點了,若是你的面試官說有其他的優點,那你完全可以告訴他,請你回去自己總結下索引這個到底是干什么的吧)
索引類型:
根據數據庫的功能,可以在數據庫設計器中創建四種索引:唯一索引、非唯一索引、主鍵索引和聚集索引。盡管唯一索引有助于定位信息,但為獲得最佳性能結果,建議改用主鍵或唯一約束。
唯一索引:
唯一索引是不允許其中任何兩行具有相同索引值的索引。
當現有數據中存在重復的鍵值時,大多數數據庫不允許將新創建的唯一索引與表一起保存。數據庫還可能防止添加將在表中創建重復鍵值的新數據。例如,如果在 employee 表中職員的姓(lname)上創建了唯一索引,則任何兩個員工都不能同姓。
非唯一索引:
非唯一索引是相對唯一索引,允許其中任何兩行具有相同索引值的索引。
當現有數據中存在重復的鍵值時,數據庫是允許將新創建的索引與表一起保存。這時數據庫不能防止添加將在表中創建重復鍵值的新數據。
主鍵索引:
數據庫表經常有一列或列組合,其值唯一標識表中的每一行。該列稱為表的主鍵。
在數據庫關系圖中為表定義主鍵將自動創建主鍵索引,主鍵索引是唯一索引的特定類型。該索引要求主鍵中的每個值都唯一。當在查詢中使用主鍵索引時,它還允許對數據的快速訪問。
聚集索引(也叫聚簇索引):
在聚集索引中,表中行的物理順序與鍵值的邏輯(索引)順序相同。一個表只能包含一個聚集索引。
如果某索引不是聚集索引,則表中行的物理順序與鍵值的邏輯順序不匹配。與非聚集索引相比,聚集索引通常提供更快的數據訪問速度。
第五篇:初級PHP程序員測試題
初級PHP工程師筆試題
1.2.3.4.請解釋一下什么oop,具有哪些特征,基本原則是什么 請說一下接口和類的區別 請列舉一下常見的設計模式及特點 請問session怎么實現,結合項目談談都是怎么使用的5.請列舉常見的sql優化方式并重點闡述
6.寫出提取網頁中url的正則表達式
7.請講下代理和反向代理的區別
8.版本控制用過什么工具
9.實際開發中用過什么開發框架,實現了哪些功能
答題人:答題日期: