執(zhí)行程序總結(jié)一系列的測試程序已經(jīng)被運(yùn)行去測量SQLite 2.7.6,PostgreSQL 7.1.3,和 MySQL 3.23.41 的相對性能。以下是根據(jù)實驗得出的一些總結(jié):
SQLite 2.7.6 是非常快的,有時可以比安裝在RedHat 7.2 上的預(yù)置的PostgreSQL 7.1.3 快10倍甚至20倍。
SQLite 2.7.6 總是很快, 有時比MySQL 3.23.41 快2倍多。
SQLite 執(zhí)行CREATE INDEX or DROP TABLE時不像其它數(shù)據(jù)庫那樣快。但這不是什么問題,因為這些是很少運(yùn)用的操作。
如果你把 multiple 操作聚集到一個單獨(dú)的事物項,SQLite可以更快些。
但以下幾點是值得注意的:
這些測試程序不是在測量多用戶使用時數(shù)據(jù)庫的性能,也不是在測量包含multiple的最優(yōu)化復(fù)雜查詢。
這些測試是在一個相對小的數(shù)據(jù)庫里完成的(大約14兆字節(jié))。 它們沒有測試數(shù)據(jù)庫引擎的大小對程序運(yùn)行速度的影響有多大。
測試環(huán)境測試所用的平臺是一個具有1GB內(nèi)存的1.6GHz Athlon和一個IDE驅(qū)動硬盤。操作系統(tǒng)是具有一個stock內(nèi)核的RedHat Linux 7.2 。使用的PostgreSQL 和MySQL服務(wù)器被RedHat 7.2 中的默認(rèn)程序所傳送。(PostgreSQL 7.1.3 版和MySQL3.23.41版)所使用的引擎自始至終沒有被調(diào)整過。需要特別注意的是,RedHat 7.2 中默認(rèn)的MYSQL配置不支持處理事物項,這一點使MYSQL的速度大大增加。但SQLite還是有能力完成大部分的測試的。
我被告知,RedHat 7.3 中預(yù)設(shè)的PostgreSQL配置是非常落后的(它必須在具有 8MB RAM 的機(jī)器上工作)。 and that PostgreSQL則可以通過調(diào)整一些配置來運(yùn)行的快些。 Matt Sergeant 報道說他已經(jīng)調(diào)整了他的PostgreSQL裝置,并且像下面所顯示的一樣重新進(jìn)行測試。他的結(jié)果顯示 PostgreSQL和MySQL運(yùn)行速度一樣。如想查看結(jié)果,訪問:http://www.sergeant.org/sqlite_vs_pgsync.htmlSQLite實在同樣的配置下被測試的,它是用 -O6 optimization 和 -DNDEBUG=1 交叉編寫,這樣使許多SQLite代碼中的"assert()"語句 無法運(yùn)行。
所有的測試都是在一個靜止的機(jī)器上進(jìn)行的。所有的測試時由一個簡單的TCL文稿編排程序產(chǎn)生和運(yùn)行的。 A copy of this Tcl script can be found in the你可以在源文件目錄文件SQLite source tree in the filetools/speedtest.tcl中發(fā)現(xiàn)TCL文稿編排程序的副本. 所有測試中的時間都是以精確到秒的背景時鐘來計算的.SQLite有兩個單獨(dú)的時間值. 第一個時間值在一個完整磁盤同步化打開的默認(rèn)裝置里.同步話打開后,為了確保重要數(shù)據(jù)已被真正的寫入磁盤驅(qū)動表面,SQLite在關(guān)鍵的時候執(zhí)行fsync()系統(tǒng)調(diào)用. 在數(shù)據(jù)庫更新過程中,當(dāng)操作系統(tǒng)崩潰時或者計算機(jī)突然斷電時,為了保證數(shù)據(jù)庫的完整性,同步化是非常有必要的.第二個時間值是當(dāng)同步化關(guān)閉的時候.關(guān)閉同步化, SQLite有時會運(yùn)行的快些,但如果系統(tǒng)崩潰或者突然斷電數(shù)據(jù)庫將會受到損失. 通常來說,同步化的SQLite的時間是為了和PostgreSQL(因為他也是同步化的)比較,異步化的SQLite是為了和也是異步化的MySQL引擎比較.
測試 1: 1000 INSERTs
CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100));
INSERT INTO t1 VALUES(1,13153,'thirteen thousand one hundred fifty three');
INSERT INTO t1 VALUES(2,75560,'seventy five thousand five hundred sixty');
... 995 lines omitted
INSERT INTO t1 VALUES(998,66289,'sixty six thousand two hundred eighty nine');
INSERT INTO t1 VALUES(999,24322,'twenty four thousand three hundred twenty two');
INSERT INTO t1 VALUES(1000,94142,'ninety four thousand one hundred forty two');
| PostgreSQL: | 4.373 |
| MySQL: | 0.114 |
| SQLite 2.7.6: | 13.061 |
| SQLite 2.7.6 (nosync): | 0.223 |
因為沒有一個中央服務(wù)器來控制訪問,SQLite必須先關(guān)閉再打開數(shù)據(jù)庫文件,這樣高速緩存器就失去了作用。在這個測試中,每個 SQL語句都是一個獨(dú)立的事務(wù)元,所以數(shù)據(jù)庫文件必須被打開和關(guān)閉,高速緩存必須刷新1000次。盡管這樣,異步版本的SQLite還是和MYSQL一樣快。但同步版本的卻是非常慢。SQLite在每個同步事務(wù)元后調(diào)用fsync(),因而確保了磁盤表面所有的數(shù)據(jù)都是安全的。13秒的測試時間大部分都被用于磁盤I/O。