熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> MySQL >> 正文

Mysql數據庫領域的中間派

2013-11-23 20:56:26  來源: MySQL 

  MySQL是一個廣受Linux社區人們喜愛的半商業的數據庫 MySQL是可運行在大多數的Linux平台(iSparcetc)以及少許非Linux甚至非Unix平台
  
  許可費用
  MySQL的普及很大程度上源於它的寬松除了略顯不尋常的許可費用MySQL的價格隨平台和安裝方式變化MySQL的Windows版本(NT和X)在任何情況下都不免費而任何Unix變種(包括Linux)的MySQL如果由用戶自己或系統管理員而不是第三方安裝則是免費的第三方案莊則必須付許可費
  
  價格
  平台 安裝方式 價格
  Windows NTX 任何 美元
  Unix或Linux 自行安裝 免費
  Unix或Linux 第三方安裝 美元
  需要一個應用組件 美元
  
  可以得到多種支持合同內容太多不再羅列最新報價可咨詢MySQL站點
  
  安裝
  可以在MySQL站點上獲得大多數主要的軟件包格式(RPMDBETGZ)客戶端庫和各種語言包裝(Wrapper)可以分開的RPM格式獲得RPM格式的安裝沒有多大麻煩並且無需初始配置在rcd(以RedHat RPM為例)生成一個初始腳本故MySQL守護進程在多用戶模式下重啟時被啟動運行MySQL的守護進程(mysqld)消耗很少的內存(在運行RedHat 的奔騰每個守護進程使用K內存和另外M共享內存的開銷)並在只有在執行真正的查詢時才裝載到處理器上這意味著對小型數據庫來說MySQL可以相當輕松地使用而不會對其他系統功能有太大的影響
  
  數據類型
  字段支持大量數據類型是件好事通常的整數浮點數字符串和數字均以多種長度表示並支持變長的BLOB(Binary Large OBject)類型對整數字段由自動增量選項日期時間字段也能很好的表示
  
  MySQL與大多數其他數據庫系統不同的是提供兩個相對不常用的字段類型ENUM和SETENUM是一個枚舉類型非常類適於Pascal語言的枚舉類型它允許程序員看到類似於redgreenblue的字段值而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) PerlPathon和PHP只是一部分Apache的Web服務器也有許多模塊例如目錄存取文件等允許各種各樣的Apache配置信息(例如目錄存取文件)使用MySQL應用程序接口簡單一致並且相但完整另外多平台ODBC驅動程序可自由獲得
  
  未來
  MySQL的開發繼續以快速進行著事實上開發步伐對大多數開放源代碼是一種挑戰本文提到的幾個抱怨中有很多新功能正在解決然而我將不對還沒確實存在的特征做評價開發者們向我表明了在未來的開發中把增加查詢功能和提高查詢速度作為最高優先級
  
  總結
  Mysql是數據庫領域的中間派它缺乏一個全功能數據庫的大多數主要特征但是又有比類似Xbase記錄存儲引擎更多的特征它象企業級RDBMS那樣需要一個積極的服務者守護程序但是不能象他們那樣消費資源查詢語言允許復雜的連接(join)查詢但是所有的參考完整必須由程序員強制保證
  
  MySQL在Linux世界裡找到一個位置-提供簡潔和速度同時仍然提供足夠的功能使程序員高興數據庫程序員將喜歡其查詢功能和廣泛的客戶庫數據庫管理員會覺得系統缺乏主要數據庫功能他們會發覺它對簡單數據庫(在不能保證購買大牌數據庫時)是有價值的

From:http://tw.wingwit.com/Article/program/MySQL/201311/29327.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.