MySQL是一個廣受Linux社區人們喜愛的半商業的資料庫。 MySQL是可運行在大多數的Linux平台(i386,Sparc,etc),以及少許非Linux甚至非Unix平台。
1、許可費用
MySQL的普及很大程度上源於它的寬鬆,除了略顯不尋常的許可費用。MySQL的價格隨平台和安裝方式變化。MySQL的Windows版本NT和9X)在任何情況下都不免費,而任何Unix變種包括Linux)的MySQL如果由使用者自己或系統管理員而不是第三方安裝則是免費的,第三方案莊則必須付許可費。
2、價格
平台 安裝方式 價格
Windows NT,9X 任何 200美元
Unix或Linux 自行安裝 免費
Unix或Linux 第三方安裝 200美元
需要一個應用組件 200美元
可以得到多種支援合約,內容太多不再羅列,最新報價可諮詢MySQL網站。
3、安裝
可以在MySQL網站上獲得大多數主要的軟體包格式RPM、DBE、TGZ),用戶端庫和各種語言“封裝”Wrapper)可以分開的RPM格式獲得。RPM格式的安裝沒有多大麻煩,並且無需初始配置。在rc3.d以RedHat RPM為例)產生一個初始指令碼,故MySQL守護進程在多使用者模式下重啟時被啟動運行。MySQL的守護進程mysqld)消耗很少的記憶體在運行RedHat 5.1的奔騰133上,每個守護進程使用500K記憶體和另外4M共用記憶體的開銷)並在只有在執行真正的查詢時才裝載到處理器上,這意味著對小型資料庫來說,MySQL可以相當輕鬆地使用而不會對其他系統功能有太大的影響。
4、資料類型
欄位支援大量資料類型是件好事。通常的整數、浮點數、字串和數字均以多種長度表示,並支援變長的BLOBBinary Large OBject)類型。對整數欄位由自動增量選項,日期時間欄位也能很好的表示。
MySQL與大多數其他資料庫系統不同的是提供兩個相對不常用的欄位類型:ENUM和SET。ENUM是一個枚舉類型,非常類適於Pascal語言的枚舉類型,它允許程式員看到類似於'red、'green'、'blue'的欄位值,而MySQL只將這些值儲存為一個位元組。SET也是從Pascal借用的,它也是一個枚舉類型,但一個單獨欄位一次可儲存多個值,這種儲存多個枚舉值的能力也許不會給你一些印象並可能威脅第三範式定義),但正確使用SET和CONTAINS關鍵字可以省去很多表串連,能獲得很好的效能提高。
5、SQL相容性
MySQL包含一些與SQL標準不同的轉變,他們的大多數被設計成是對SQL語言指令碼語言的不足的一種補償。然而,另一些擴充確實使 MySQL與眾不同,例如,LINK子句搜尋是自動地忽略大小寫。MySQL 也允許使用者自訂的SQL函數,換句話說,一個程式員可以編寫一個函數然後整合到MySQL中,並且其表現的與任何基本函數如SUM()或AVG ()沒有什麼不同。函數必須被編譯道一個共用庫檔案中(.so檔案),然後用一個LOAD FUNCTION命令裝載。
它也缺乏一些常用的SQL功能,沒有子選擇(在查詢中的查詢)。視圖(View)也沒了。當然大多數子查詢可以用簡單的串連(join)子句重寫,但有時用兩個嵌套的查詢思考問題比一個大串連容易。同樣,視圖僅僅為程式員隱蔽where子句,但這正是程式員們期望的另一種便利。
6、預存程序和觸發器
MySQL沒有一種預存程序(Stored Procedure)語言,這是對習慣於企業級資料庫的程式員的最大限制。多語句SQL命令必須通過客戶方代碼來協調,這種情形是藉助於相當健全的查詢語言和賦予用戶端鎖定和解鎖表的能力,這樣才允許的多語句運行。
7、參考完整性Referential Integrity-RI)
MySQL的主要的缺陷之一是缺乏標準的RI機制;然而,MySQL的創造者也不是對其使用者的願望置若罔聞,並且提供了一些解決辦法。其中之一是支援唯一索引。Rule限制的缺乏(在給釘欄位域上的一種固定的範圍限制)通過大量的資料類型來補償。不簡單地提供檢查約束(一個欄位相對於同一行的另一個欄位的之值的限制)、外部關鍵字和經常與RI相關的“串聯刪除”功能。有趣的是,當不支援這些功能時,SQL分析器容忍這些語句的句法。這樣做目的是易於移植資料庫到MySQL中。這是一個很好的嘗試,並且它確實未來支援該功能留下方便之門;然而,那些沒有仔細閱讀文檔的的人可能誤以為這些功能實際上是存在的。
8、安全性
自始至終我對MySQL最大的抱怨是其安全系統,它唯一的缺點是複雜而非標準,另外只有到調用mysqladmin來重讀使用者權限時才發生改變。通常的SQL GRANT/REVOKE 語句到最近的版本才被支援,但是至少他們現在有了。 MySQL的編寫者廣泛地記載了其特定的安全性系統,但是它確實需要一條可能是別無它法的學習過程。
9、備份和恢複、資料匯入/匯出
強制參考一致性的缺乏顯著地簡化備份和恢複,單靠資料匯入/匯出就可完美複製這一功能。LOAD DATA INFILE命令給了資料匯入很大的靈活性。SELECT INTO命令實現了資料匯出的相等功能。另外,既然MySQL不使用原始的分區,所有的資料庫資料能用一個檔案系統備份儲存。資料庫活動能被記載。與通常的資料庫日誌不同(儲存記錄變化或在記錄映像之前/之後), MySQL記載實際的SQL語句。這允許資料庫被恢複到失敗前的那一點,但是不允許提交(commit)和回卷(rollback)操作.
9、串連性
MySQL客戶庫是客戶/伺服器結構的C語言庫,它意味著一個客戶能查詢駐留在另一台機器的一個資料庫。然而MySQL真正的強項處於該庫中的語言“封裝器(wrapper)”, Perl、Pathon和PHP只是一部分。Apache的Web伺服器也有許多模組例如目錄存取檔案等允許各種各樣的Apache配置資訊(例如目錄存取檔案)使用MySQL,應用程式介面簡單、一致並且相但完整。另外、多平台ODBC驅動程式可自由獲得。
10、未來
MySQL的開發繼續以快速進行著。事實上,開發步伐對大多數開放原始碼是一種挑戰。本文提到的幾個抱怨中有很多新功能正在解決,然而,我將不對還沒確實存在的特徵做評價。開發人員們向我表明了在未來的開發中把增加查詢功能和提高查詢速度作為最高優先順序。
11、總結
Mysql是資料庫領域的中間派。它缺乏一個全功能資料庫的大多數主要特徵,但是又有比類似Xbase記錄儲存引擎更多的特徵。它象企業級RDBMS那樣需要一個積極的服務者精靈,但是不能象他們那樣消費資源。查詢語言允許複雜的串連(join)查詢,但是所有的參考完整必須由程式員強制保證。
MySQL在Linux世界裡找到一個位置-提供簡潔和速度,同時仍然提供足夠的功能使程式員高興。資料庫程式員將喜歡其查詢功能和廣泛的客戶庫,資料庫管理員會覺得系統缺乏主要資料庫功能,他們會發覺它對簡單資料庫(在不能保證購買大牌資料庫時)是有價值的。
- 資料庫廠商的發展曆史之MySQL
- MySQL 5.1正式版準備就緒即將公開發布
- MySQL聯合創始人已向Sun遞交辭呈