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