| MySQL簡(jiǎn)介 | |
MySQL是一個(gè)廣受Linux社區人們喜愛(ài)的半商業(yè)的數據庫。 MySQL是可運行在大多數的Linux平臺(i386,Sparc,etc),以及少許非Linux甚至非Unix平臺。 1、許可費用 MySQL的普及很大程度上源于它的寬松,除了略顯不尋常的許可費用。MySQL的價(jià)格隨平臺和安裝方式變化。MySQL的Windows版本(NT和9X)在任何情況下都不免費,而任何Unix變種(包括Linux)的MySQL如果由用戶(hù)自己或系統管理員而不是第三方安裝則是免費的,第三方案莊則必須付許可費。 2、價(jià)格 平臺 安裝方式 價(jià)格 3、安裝 可以在MySQL站點(diǎn)上獲得大多數主要的軟件包格式(RPM、DBE、TGZ),客戶(hù)端庫和各種語(yǔ)言“包裝”(Wrapper)可以分開(kāi)的RPM格式獲得。RPM格式的安裝沒(méi)有多大麻煩,并且無(wú)需初始配置。在rc3.d(以RedHat RPM為例)生成一個(gè)初始腳本,故MySQL守護進(jìn)程在多用戶(hù)模式下重啟時(shí)被啟動(dòng)運行。MySQL的守護進(jìn)程(mysqld)消耗很少的內存(在運行RedHat 5.1的奔騰133上,每個(gè)守護進(jìn)程使用500K內存和另外4M共享內存的開(kāi)銷(xiāo))并在只有在執行真正的查詢(xún)時(shí)才裝載到處理器上,這意味著(zhù)對小型數據庫來(lái)說(shuō),MySQL可以相當輕松地使用而不會(huì )對其他系統功能有太大的影響。 4、數據類(lèi)型 字段支持大量數據類(lèi)型是件好事。通常的整數、浮點(diǎn)數、字符串和數字均以多種長(cháng)度表示,并支持變長(cháng)的BLOB(Binary Large OBject)類(lèi)型。對整數字段由自動(dòng)增量選項,日期時(shí)間字段也能很好的表示。 MySQL與大多數其他數據庫系統不同的是提供兩個(gè)相對不常用的字段類(lèi)型:ENUM和SET。ENUM是一個(gè)枚舉類(lèi)型,非常類(lèi)適于Pascal語(yǔ)言的枚舉類(lèi)型,它允許程序員看到類(lèi)似于‘red、‘green‘、‘blue‘的字段值,而MySQL只將這些值存儲為一個(gè)字節。SET也是從Pascal借用的,它也是一個(gè)枚舉類(lèi)型,但一個(gè)單獨字段一次可存儲多個(gè)值,這種存儲多個(gè)枚舉值的能力也許不會(huì )給你一些印象(并可能威脅第三范式定義),但正確使用SET和CONTAINS關(guān)鍵字可以省去很多表連接,能獲得很好的性能提高。 5、SQL兼容性 MySQL包含一些與SQL標準不同的轉變,他們的大多數被設計成是對SQL語(yǔ)言腳本語(yǔ)言的不足的一種補償。然而,另一些擴展確實(shí)使 MySQL與眾不同,例如,LINK子句搜索是自動(dòng)地忽略大小寫(xiě)的。MySQL 也允許用戶(hù)自定義的SQL函數,換句話(huà)說(shuō),一個(gè)程序員可以編寫(xiě)一個(gè)函數然后集成到MySQL中,并且其表現的與任何基本函數如SUM()或AVG ()沒(méi)有什么不同。函數必須被編譯道一個(gè)共享庫文件中(.so文件),然后用一個(gè)LOAD FUNCTION命令裝載。 它也缺乏一些常用的SQL功能,沒(méi)有子選擇(在查詢(xún)中的查詢(xún))。視圖(View)也沒(méi)了。當然大多數子查詢(xún)可以用簡(jiǎn)單的連接(join)子句重寫(xiě),但有時(shí)用兩個(gè)嵌套的查詢(xún)思考問(wèn)題比一個(gè)大連接容易。同樣,視圖僅僅為程序員隱蔽where子句,但這正是程序員們期望的另一種便利。 6、存儲過(guò)程和觸發(fā)器 MySQL沒(méi)有一種存儲過(guò)程(Stored Procedure)語(yǔ)言,這是對習慣于企業(yè)級數據庫的程序員的最大限制。多語(yǔ)句SQL命令必須通過(guò)客戶(hù)方代碼來(lái)協(xié)調,這種情形是借助于相當健全的查詢(xún)語(yǔ)言和賦予客戶(hù)端鎖定和解鎖表的能力,這樣才允許的多語(yǔ)句運行。 7、參考完整性(Referential Integrity-RI) MySQL的主要的缺陷之一是缺乏標準的RI機制;然而,MySQL的創(chuàng )造者也不是對其用戶(hù)的愿望置若罔聞,并且提供了一些解決辦法。其中之一是支持唯一索引。Rule限制的缺乏(在給釘字段域上的一種固定的范圍限制)通過(guò)大量的數據類(lèi)型來(lái)補償。不簡(jiǎn)單地提供檢查約束(一個(gè)字段相對于同一行的另一個(gè)字段的之值的限制)、外部關(guān)鍵字和經(jīng)常與RI相關(guān)的“級聯(lián)刪除”功能。有趣的是,當不支持這些功能時(shí),SQL分析器容忍這些語(yǔ)句的句法。這樣做目的是易于移植數據庫到MySQL中。這是一個(gè)很好的嘗試,并且它確實(shí)未來(lái)支持該功能留下方便之門(mén);然而,那些沒(méi)有仔細閱讀文檔的的人可能誤以為這些功能實(shí)際上是存在的。 7、安全性 自始至終我對MySQL最大的抱怨是其安全系統,它唯一的缺點(diǎn)是復雜而非標準,另外只有到調用mysqladmin來(lái)重讀用戶(hù)權限時(shí)才發(fā)生改變。通常的SQL GRANT/REVOKE 語(yǔ)句到最近的版本才被支持,但是至少他們現在有了。 MySQL的編寫(xiě)者廣泛地記載了其特定的安全性系統,但是它確實(shí)需要一條可能是別無(wú)它法的學(xué)習過(guò)程。 8、備份和恢復、數據導入/導出 強制參考一致性的缺乏顯著(zhù)地簡(jiǎn)化備份和恢復,單靠數據導入/導出就可完美復制這一功能。LOAD DATA INFILE命令給了數據導入很大的靈活性。SELECT INTO命令實(shí)現了數據導出的相等功能。另外,既然MySQL不使用原始的分區,所有的數據庫數據能用一個(gè)文件系統備份保存。數據庫活動(dòng)能被記載。與通常的數據庫日志不同(存儲記錄變化或在記錄映像之前/之后), MySQL記載實(shí)際的SQL語(yǔ)句。這允許數據庫被恢復到失敗前的那一點(diǎn),但是不允許提交(commit)和回卷(rollback)操作.
10、未來(lái) MySQL的開(kāi)發(fā)繼續以快速進(jìn)行著(zhù)。事實(shí)上,開(kāi)發(fā)步伐對大多數開(kāi)放源代碼是一種挑戰。本文提到的幾個(gè)抱怨中有很多新功能正在解決,然而,我將不對還沒(méi)確實(shí)存在的特征做評價(jià)。開(kāi)發(fā)者們向我表明了在未來(lái)的開(kāi)發(fā)中把增加查詢(xún)功能和提高查詢(xún)速度作為最高優(yōu)先級。 11、總結 MySQL在Linux世界里找到一個(gè)位置-提供簡(jiǎn)潔和速度,同時(shí)仍然提供足夠的功能使程序員高興。數據庫程序員將喜歡其查詢(xún)功能和廣泛的客戶(hù)庫,數據庫管理員會(huì )覺(jué)得系統缺乏主要數據庫功能,他們會(huì )發(fā)覺(jué)它對簡(jiǎn)單數據庫(在不能保證購買(mǎi)大牌數據庫時(shí))是有價(jià)值的。 |
聯(lián)系客服