程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL查詢時間段使用INT還是DateTime的測試

MySQL查詢時間段使用INT還是DateTime的測試

編輯:MySQL綜合教程

在MySQL查詢時間段的時候,選擇INT會更高效,還是選擇DateTime會更為高效呢?針對此問題,下面將做一個測試,看看MySQL查詢時間段究竟應該使用INT還是DateTime。

環境:

Windows XP
PHP Version 5.2.9
MySQL Server 5.1 

第一步、創建一個表date_test非定長、int時間)

CREATE TABLE `test`.`date_test` (
`id` INT NOT NULL AUTO_INCREMENT ,
`start_time` INT NOT NULL ,
`some_content` VARCHAR( 255 ) NOT NULL ,
PRIMARY KEY ( `id` )
) ENGINE = InnoDB;

第二步、創建第二個表date_test2定長、int時間)

CREATE TABLE `test`.`date_test2` (
`id` INT NOT NULL AUTO_INCREMENT ,
`start_time` INT NOT NULL ,
`some_content` CHAR( 255 ) NOT NULL ,
PRIMARY KEY ( `id` )
) ENGINE = InnoDB;

第三步、創建第三個表date_test3varchar、datetime時間)

CREATE TABLE `test`.`date_test3` (
`id` INT NOT NULL AUTO_INCREMENT ,
`start_time` DATETIME NOT NULL ,
`some_content` VARCHAR( 255 ) NOT NULL ,
PRIMARY KEY ( `id` )
) ENGINE = InnoDB;

第四步、創建第四個表date_test3char、datetime時間)

CREATE TABLE `test`.`date_test4` (
`id` INT NOT NULL AUTO_INCREMENT ,
`start_time` DATETIME NOT NULL ,
`some_content` CHAR( 255 ) NOT NULL ,
PRIMARY KEY ( `id` )
) ENGINE = InnoDB;

ok,現在我們開始做測試,環境是php,先向各個表插入一百萬條數據。插入的時候分200次,每次進庫5000條。

表一執行記錄:頁面運行時間: 26.5997889042 秒,插入的時候發現一個有趣的現象:SELECT count( id ) FROM `date_test` WHERE 1 的結果是100w,而直接select * from `date_test`卻是1,000,374條結果。後來看到這是一個可能接近的值,請參看MySQL FAQ 3.11)。

表二執行記錄:頁面運行時間: 62.3908278942 秒,這次記錄是1,000,066條。

表三執行記錄:頁面運行時間: 30.2576560974 秒,這次的是1,000,224條。

表四執行記錄:頁面運行時間: 67.5393900871 秒,這次的是:1,000,073條。

現在把四個表的start_time字段一一加上索引。

測試四個表的更新,分別update 100條記錄,並記錄時間:

表一:頁面運行時間: 2.62180089951 秒非定長,int時間)

表二:頁面運行時間: 2.5475358963 秒定長,int時間)

表三:頁面運行時間: 2.45077300072 秒varchar,datetime時間)

表四:頁面運行時間: 2.82798409462 秒char,datetime時間)

測試四個表的讀取,分別select 100條隨機記錄,以主鍵id為條件查詢,並記錄時間:

表一:頁面運行時間: 0.382651090622 秒非定長,int時間)

表二:頁面運行時間: 0.542181015015 秒定長,int時間)

表三:頁面運行時間: 0.334048032761 秒varchar,datetime時間)

表四:頁面運行時間: 0.506206989288 秒char,datetime時間)

測試四個表的讀取,分別select 10條隨機記錄,以star_time為條件查詢,並記錄時間:

表一:頁面運行時間: 30.1972880363 秒非定長,int時間)

表二:頁面運行時間: 65.1926910877 秒定長,int時間)

表三:頁面運行時間: 39.7210869789 秒varchar,datetime時間)

表四:頁面運行時間: 70.4632740021 秒char,datetime時間)

因為量比較小,所以我們默認即使是微小的變化,也是有意義的。

結論:

大數據量下,如果存在大量的select * from table where 時間>XX這樣的查詢,在MySQL5.1時使用int換datetime是有意義的。
 

MySQL外鍵和參照完整性的關系

MySQL轉換Oracle的七大注意事項

解讀MySQL數據庫產品定價新策略

帶您深入了解MYSQL字符串連接

詳解MySQL+Apache集群模式的實現

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved