數(shù)據(jù)庫(kù)(如oracle、mysql)及編程語(yǔ)言(php、python、perl、lisp)的區(qū)別?
一、數(shù)據(jù)庫(kù)(如oracle、mysql)及編程語(yǔ)言(php、python、perl、lisp)的區(qū)別
數(shù)據(jù)庫(kù)就是數(shù)據(jù)庫(kù),不要因?yàn)槟硞€(gè)時(shí)候被用于網(wǎng)站應(yīng)用就叫他網(wǎng)站數(shù)據(jù)庫(kù)。
這里所謂的數(shù)據(jù)庫(kù)應(yīng)該是數(shù)據(jù)庫(kù)管理系統(tǒng),如最大牌的Oracle,社區(qū)熱門(mén)的MySQL,開(kāi)源中較高級(jí)的PostgreSQL,微軟家的SQLServer等。
他們提供開(kāi)發(fā)者類似的鏈接數(shù)據(jù)庫(kù)的方式,提供基于一定標(biāo)準(zhǔn)但又各有差異的查詢語(yǔ)言,最終目標(biāo)是提供開(kāi)發(fā)者方便的查詢、插入、刪除、修改數(shù)據(jù)的能力。而不同數(shù)據(jù)庫(kù)管理系統(tǒng)性能上也有差異,在不同數(shù)據(jù)的量級(jí)、訪問(wèn)量級(jí)可能各有優(yōu)勢(shì),具體比較的參數(shù)應(yīng)該沒(méi)有必要給出了,業(yè)界好像也沒(méi)有什么統(tǒng)一的benchmark。我介紹一下在哪些情況下會(huì)選擇誰(shuí)就是了。
如果只是個(gè)人想搞點(diǎn)小應(yīng)用,小網(wǎng)站,搭個(gè)博客什么的,推薦MySQL,因?yàn)樗赓M(fèi),穩(wěn)定,在大多數(shù)情況下性能優(yōu)越,來(lái)自開(kāi)源世界,例子豐富。當(dāng)然某些大型網(wǎng)站也用他,比如Twitter,不知道知乎是不是也用……如果是商業(yè)應(yīng)用,非得跑在Windows Server上,又對(duì)微軟家的東西有執(zhí)念,可以用用SQLServer,但是其實(shí)不推薦的。如果有錢沒(méi)地方用了,應(yīng)用也是非常重量級(jí)的,可能需要更豐富的功能、強(qiáng)大的處理和相應(yīng)性能、數(shù)據(jù)倉(cāng)庫(kù)、挖掘服務(wù)、售后各種服務(wù),那就Oracle吧!絕對(duì)用到你爽……學(xué)習(xí)起來(lái)也挺不簡(jiǎn)單的,把他拿下,去公司搞數(shù)據(jù)庫(kù)應(yīng)該輕松得很了。
其實(shí)真正軟件開(kāi)發(fā)上來(lái)講,應(yīng)該避免直接去面對(duì)數(shù)據(jù)庫(kù),而應(yīng)該用一些中間件,或者至少是一些ORM工具之類的幫助完成這個(gè)工作,并進(jìn)一步的采用配置管理,使得實(shí)際應(yīng)用得以與具體數(shù)據(jù)庫(kù)系統(tǒng)、版本去耦合,如果需要切換其他數(shù)據(jù)庫(kù)只要通過(guò)配置管理調(diào)整而不需要重新寫(xiě)代碼。
各種編程語(yǔ)言不同,語(yǔ)法上就不同,適用的范圍不一樣,性能不一樣,開(kāi)發(fā)效率不一樣,而且也有個(gè)人喜好傾向之類的,而且每種語(yǔ)言背后還存在著其自有的編程思想,難以一一比較,如果感興趣,可以從一個(gè)語(yǔ)言開(kāi)始深入了解,然后逐步擴(kuò)展到其他語(yǔ)言上去,再進(jìn)行比較。
延伸閱讀:
二、為什么要持久化連接
這和 web 服務(wù)器的工作方式有關(guān)。web 服務(wù)器可以通過(guò)三種方法來(lái)利用 PHP 生成 web 頁(yè)面。
名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個(gè)單獨(dú)運(yùn)行的語(yǔ)言解釋器(CGI Wapper)。當(dāng)以這種方法運(yùn)行時(shí),PHP 會(huì)為向 web 服務(wù)器的每個(gè) PHP 頁(yè)面請(qǐng)求創(chuàng)建并銷毀 PHP 解釋器的時(shí)候?qū)嵗S捎谄鋾?huì)隨每個(gè)請(qǐng)求的結(jié)束而銷毀,因此其獲取的任何資源(例如指向 SQL 數(shù)據(jù)庫(kù)服務(wù)器的鏈接)都會(huì)在銷毀時(shí)關(guān)閉。在這種情況下,不會(huì)從使用持久連接中獲得任何好處——因?yàn)楦静粫?huì)持久。
第二,也是最流行的方法是把 PHP 用作多進(jìn)程 web 服務(wù)器的一個(gè)模塊,這種方法目前只適用于 Apache。多進(jìn)程的服務(wù)器通常有一個(gè)父進(jìn)程和一組子進(jìn)程協(xié)調(diào)運(yùn)行,子進(jìn)程負(fù)責(zé)提供網(wǎng)頁(yè)的工作。每當(dāng)接收達(dá)到客戶端提出請(qǐng)求時(shí),該請(qǐng)求會(huì)傳遞給尚未給其它客戶端提供服務(wù)的某個(gè)子進(jìn)程。這也就是說(shuō)當(dāng)相同的客戶端第二次向服務(wù)端發(fā)出請(qǐng)求時(shí),它將有可能由與名列前茅次不同的某個(gè)子進(jìn)程提供服務(wù)。在開(kāi)啟了一個(gè)持久連接后,所有請(qǐng)求 SQL 服務(wù)的后繼頁(yè)面都能夠重用與 SQL 服務(wù)器建立的相同連接。
最后一種方法是將 PHP 用作多線程 web 服務(wù)器的插件。目前 PHP 支持 WSAPI 和 NSAPI(在 Windows 上),允許 PHP 作為 Netscape FastTrack(iPlanet)、Microsoft 的 Internet Information Server (IIS) 和 O’Reilly 的 WebSite Pro 等多線程服務(wù)器的插件使用。該行為與前面描述的多過(guò)程模型相同。

猜你喜歡LIKE
相關(guān)推薦HOT
更多>>
mysql怎么查看連接池是否已滿?
一、mysql怎么查看連接池是否已滿1.查看連接數(shù)配置(MySQL服務(wù)器允許的最大連接數(shù)16384)show variables like ‘%max_connections%’2.查看當(dāng)前...詳情>>
2023-10-17 21:20:19
什么是職場(chǎng)情商,如何提高?
什么是情商?情商是一個(gè) 20 世紀(jì) 90 年代作為學(xué)術(shù)話題出現(xiàn)的概念,并迅速成為商業(yè)心理學(xué)和職場(chǎng)動(dòng)態(tài)研究的重要組成部分。它通常被稱為 EQ(情商...詳情>>
2023-10-17 20:16:30
vector, list, map等容器使用場(chǎng)合是什么?
一、vector, list, map等容器使用場(chǎng)合vector適用于對(duì)象簡(jiǎn)單,變化較小,并且頻繁隨機(jī)訪問(wèn)的場(chǎng)景。list適用經(jīng)常進(jìn)行插入和刪除并且不經(jīng)常隨機(jī)訪...詳情>>
2023-10-17 19:45:03
數(shù)據(jù)挖掘中涉及的關(guān)聯(lián)規(guī)則在實(shí)際生活中的應(yīng)用有哪些?
一、數(shù)據(jù)挖掘中涉及的關(guān)聯(lián)規(guī)則在實(shí)際生活中的應(yīng)用關(guān)于關(guān)聯(lián)規(guī)則分析,這篇文章可以認(rèn)真學(xué)習(xí)一下,講的比較全面,關(guān)聯(lián)規(guī)則分析還在零售、快消、電...詳情>>
2023-10-17 18:40:06熱門(mén)推薦
sql server2012r2所在服務(wù)器做端口限制,需要開(kāi)放什么端口才能繼續(xù)訪問(wèn)數(shù)據(jù)庫(kù)?
沸Oracle有什么優(yōu)勢(shì)和劣勢(shì)?
熱數(shù)據(jù)庫(kù)聚集索引非聚集索引實(shí)現(xiàn)上有哪些區(qū)別?
熱數(shù)據(jù)庫(kù)(如oracle、mysql)及編程語(yǔ)言(php、python、perl、lisp)的區(qū)別?
新CSS 隱藏頁(yè)面元素有哪些方法?
除了cx_Oracle,python還可以通過(guò)什么方式訪問(wèn)Oracle數(shù)據(jù)庫(kù)?
SQL開(kāi)啟事務(wù)處理的語(yǔ)句 START TRANSACTION 和BEGIN TRAN的區(qū)別?
Android適配你需要學(xué)習(xí)哪些?
開(kāi)發(fā)web應(yīng)用,好的開(kāi)發(fā)流程是怎么樣的?
為什么說(shuō)Gradle是Android進(jìn)階繞不去的坎?
mysql怎么查看連接池是否已滿?
WHERE中有很多IN判斷怎么提速?
軟件開(kāi)發(fā)要遵循哪些事項(xiàng)?
有了innodb buffer pool為什么要有redis?
技術(shù)干貨







快速通道 更多>>
-
課程介紹
點(diǎn)擊獲取大綱 -
就業(yè)前景
查看就業(yè)薪資 -
學(xué)習(xí)費(fèi)用
了解課程價(jià)格 -
優(yōu)惠活動(dòng)
領(lǐng)取優(yōu)惠券 -
學(xué)習(xí)資源
領(lǐng)3000G教程 -
師資團(tuán)隊(duì)
了解師資團(tuán)隊(duì) -
實(shí)戰(zhàn)項(xiàng)目
獲取項(xiàng)目源碼 -
開(kāi)班地區(qū)
查看來(lái)校路線