您好,登錄后才能下訂單哦!
本篇文章為大家展示了MySQL數(shù)據(jù)庫的優(yōu)點(diǎn)有哪些,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
MySQL數(shù)據(jù)庫優(yōu)點(diǎn)有哪些
1、許可費(fèi)用
MySQL的普及很大程度上源于它的寬松,除了略顯不尋常的許可費(fèi)用。MySQL的價(jià)格隨平臺(tái)和安裝方式變化。MySQL的Windows版本(NT和9X)在任何情況下都不免費(fèi),而任何Unix變種(包括Linux)的MySQL如果由用戶自己或系統(tǒng)管理員而不是第三方安裝則是免費(fèi)的,第三方案莊則必須付許可費(fèi)。
2、價(jià)格
平臺(tái)安裝方式價(jià)格
WindowsNT,9X任何200美元
Unix或Linux自行安裝免費(fèi)
Unix或Linux第三方安裝200美元
需要一個(gè)應(yīng)用組件200美元
可以得到多種支持合同,內(nèi)容太多不再羅列,最新報(bào)價(jià)可咨詢MySQL站點(diǎn)。
3、安裝
可以在MySQL站點(diǎn)上獲得大多數(shù)主要的軟件包格式(RPM、DBE、TGZ),客戶端庫和各種語言“包裝”(Wrapper)可以分開的RPM格式獲得。RPM格式的安裝沒有多大麻煩,并且無需初始配置。在rc3.d(以RedHatRPM為例)生成一個(gè)初始腳本,故MySQL守護(hù)進(jìn)程在多用戶模式下重啟時(shí)被啟動(dòng)運(yùn)行。MySQL的守護(hù)進(jìn)程(mysqld)消耗很少的內(nèi)存(在運(yùn)行RedHat5.1的奔騰133上,每個(gè)守護(hù)進(jìn)程使用500K內(nèi)存和另外4M共享內(nèi)存的開銷)并在只有在執(zhí)行真正的查詢時(shí)才裝載到處理器上,這意味著對(duì)小型數(shù)據(jù)庫來說,MySQL可以相當(dāng)輕松地使用而不會(huì)對(duì)其他系統(tǒng)功能有太大的影響。
4、數(shù)據(jù)類型
字段支持大量數(shù)據(jù)類型是件好事。通常的整數(shù)、浮點(diǎn)數(shù)、字符串和數(shù)字均以多種長度表示,并支持變長的BLOB(BinaryLargeOBject)類型。對(duì)整數(shù)字段由自動(dòng)增量選項(xiàng),日期時(shí)間字段也能很好的表示。
MySQL與大多數(shù)其他數(shù)據(jù)庫系統(tǒng)不同的是提供兩個(gè)相對(duì)不常用的字段類型:ENUM和SET。ENUM是一個(gè)枚舉類型,非常類適于Pascal語言的枚舉類型,它允許程序員看到類似于'red、'green'、'blue'的字段值,而MySQL只將這些值存儲(chǔ)為一個(gè)字節(jié)。SET也是從Pascal借用的,它也是一個(gè)枚舉類型,但一個(gè)單獨(dú)字段一次可存儲(chǔ)多個(gè)值,這種存儲(chǔ)多個(gè)枚舉值的能力也許不會(huì)給你一些印象(并可能威脅第三范式定義),但正確使用SET和CONTAINS關(guān)鍵字可以省去很多表連接,能獲得很好的性能提高。
5、SQL兼容性
MySQL包含一些與SQL標(biāo)準(zhǔn)不同的轉(zhuǎn)變,他們的大多數(shù)被設(shè)計(jì)成是對(duì)SQL語言腳本語言的不足的一種補(bǔ)償。然而,另一些擴(kuò)展確實(shí)使MySQL與眾不同,例如,LINK子句搜索是自動(dòng)地忽略大小寫的。MySQL也允許用戶自定義的SQL函數(shù),換句話說,一個(gè)程序員可以編寫一個(gè)函數(shù)然后集成到MySQL中,并且其表現(xiàn)的與任何基本函數(shù)如SUM()或AVG()沒有什么不同。函數(shù)必須被編譯道一個(gè)共享庫文件中(.so文件),然后用一個(gè)LOADFUNCTION命令裝載。
它也缺乏一些常用的SQL功能,沒有子選擇(在查詢中的查詢)。視圖(View)也沒了。當(dāng)然大多數(shù)子查詢可以用簡單的連接(join)子句重寫,但有時(shí)用兩個(gè)嵌套的查詢思考問題比一個(gè)大連接容易。同樣,視圖僅僅為程序員隱蔽where子句,但這正是程序員們期望的另一種便利。
MySQL數(shù)據(jù)庫優(yōu)點(diǎn)有哪些
6、存儲(chǔ)過程和觸發(fā)器
MySQL沒有一種存儲(chǔ)過程(StoredProcedure)語言,這是對(duì)習(xí)慣于企業(yè)級(jí)數(shù)據(jù)庫的程序員的最大限制。多語句SQL命令必須通過客戶方代碼來協(xié)調(diào),這種情形是借助于相當(dāng)健全的查詢語言和賦予客戶端鎖定和解鎖表的能力,這樣才允許的多語句運(yùn)行。
7、參考完整性(ReferentialIntegrity-RI)
MySQL的主要的缺陷之一是缺乏標(biāo)準(zhǔn)的RI機(jī)制;然而,MySQL的創(chuàng)造者也不是對(duì)其用戶的愿望置若罔聞,并且提供了一些解決辦法。其中之一是支持唯一索引。Rule限制的缺乏(在給釘字段域上的一種固定的范圍限制)通過大量的數(shù)據(jù)類型來補(bǔ)償。不簡單地提供檢查約束(一個(gè)字段相對(duì)于同一行的另一個(gè)字段的之值的限制)、外部關(guān)鍵字和經(jīng)常與RI相關(guān)的“級(jí)聯(lián)刪除”功能。有趣的是,當(dāng)不支持這些功能時(shí),SQL分析器容忍這些語句的句法。這樣做目的是易于移植數(shù)據(jù)庫到MySQL中。這是一個(gè)很好的嘗試,并且它確實(shí)未來支持該功能留下方便之門;然而,那些沒有仔細(xì)閱讀文檔的的人可能誤以為這些功能實(shí)際上是存在的。
7、安全性
自始至終我對(duì)MySQL最大的抱怨是其安全系統(tǒng),它唯一的缺點(diǎn)是復(fù)雜而非標(biāo)準(zhǔn),另外只有到調(diào)用mysqladmin來重讀用戶權(quán)限時(shí)才發(fā)生改變。通常的SQLGRANT/REVOKE語句到日前的版本才被支持,但是至少他們現(xiàn)在有了。MySQL的編寫者廣泛地記載了其特定的安全性系統(tǒng),但是它確實(shí)需要一條可能是別無它法的學(xué)習(xí)過程。
8、備份和恢復(fù)、數(shù)據(jù)導(dǎo)入/導(dǎo)出
強(qiáng)制參考一致性的缺乏顯著地簡化備份和恢復(fù),單靠數(shù)據(jù)導(dǎo)入/導(dǎo)出就可完美復(fù)制這一功能。LOADDATAINFILE命令給了數(shù)據(jù)導(dǎo)入很大的靈活性。SELECTINTO命令實(shí)現(xiàn)了數(shù)據(jù)導(dǎo)出的相等功能。另外,既然MySQL不使用原始的分區(qū),所有的數(shù)據(jù)庫數(shù)據(jù)能用一個(gè)文件系統(tǒng)備份保存。數(shù)據(jù)庫活動(dòng)能被記載。與通常的數(shù)據(jù)庫日志不同(存儲(chǔ)記錄變化或在記錄映像之前/之后),MySQL記載實(shí)際的SQL語句。這允許數(shù)據(jù)庫被恢復(fù)到失敗前的那一點(diǎn),但是不允許提交(commit)和回卷(rollback)操作.
9、連接性
MySQL客戶庫是客戶/服務(wù)器結(jié)構(gòu)的C語言庫,它意味著一個(gè)客戶能查詢駐留在另一臺(tái)機(jī)器的一個(gè)數(shù)據(jù)庫。然而MySQL真正的強(qiáng)項(xiàng)處于該庫中的語言“包裝器(wrapper)”,Perl、Pathon和PHP只是一部分。Apache的Web服務(wù)器也有許多模塊例如目錄存取文件等允許各種各樣的Apache配置信息(例如目錄存取文件)使用MySQL,應(yīng)用程序接口簡單、一致并且相但完整。另外、多平臺(tái)ODBC驅(qū)動(dòng)程序可自由獲得。
10、未來
MySQL的開發(fā)繼續(xù)以快速進(jìn)行著。事實(shí)上,開發(fā)步伐對(duì)大多數(shù)開放源代碼是一種挑戰(zhàn)。該篇文章提到的幾個(gè)抱怨中有很多新功能正在解決,然而,我將不對(duì)還沒確實(shí)存在的特征做評(píng)價(jià)。開發(fā)者們向我表明了在未來的開發(fā)中把增加查詢功能和提高查詢速度作為最高優(yōu)先級(jí)。
11、總結(jié)
Mysql是數(shù)據(jù)庫領(lǐng)域的中間派。它缺乏一個(gè)全功能數(shù)據(jù)庫的大多數(shù)主要特征,但是又有比類似Xbase記錄存儲(chǔ)引擎更多的特征。它象企業(yè)級(jí)RDBMS那樣需要一個(gè)積極的服務(wù)者守護(hù)程序,但是不能象他們那樣消費(fèi)資源。查詢語言允許復(fù)雜的連接(join)查詢,但是所有的參考完整必須由程序員強(qiáng)制保證。
MySQL在Linux世界里找到一個(gè)位置-提供簡潔和速度,同時(shí)仍然提供足夠的功能使程序員高興。數(shù)據(jù)庫程序員將喜歡其查詢功能和廣泛的客戶庫,數(shù)據(jù)庫管理員會(huì)覺得系統(tǒng)缺乏主要數(shù)據(jù)庫功能,他們會(huì)發(fā)覺它對(duì)簡單數(shù)據(jù)庫(在不能保證購買大牌數(shù)據(jù)庫時(shí))是有價(jià)值的。
上述內(nèi)容就是MySQL數(shù)據(jù)庫的優(yōu)點(diǎn)有哪些,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。