MySQL時(shí)間字段究竟使用INT還是DateTime的說(shuō)明
今天解析DEDECMS時(shí)發(fā)現(xiàn)deder的MYSQL時(shí)間字段,都是用
`senddata` int(10) unsigned NOT NULL DEFAULT '0'; |
隨后又在網(wǎng)上找到這篇文章,看來(lái)如果時(shí)間字段有參與運(yùn)算,用int更好,一來(lái)檢索時(shí)不用在字段上轉(zhuǎn)換運(yùn)算,直接用于時(shí)間比較!二來(lái)如下所述效率也更高。
歸根結(jié)底:用int來(lái)代替data類(lèi)型,更高效。
環(huán)境:
Windows XP PHP Version 5.2.9 MySQL Server 5.1 |
第一步、創(chuàng)建一個(gè)表date_test(非定長(zhǎng)、int時(shí)間)
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; |
第二步、創(chuàng)建第二個(gè)表date_test2(定長(zhǎng)、int時(shí)間)
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; |
第三步、創(chuàng)建第三個(gè)表date_test3(varchar、datetime時(shí)間)
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; |
第四步、創(chuàng)建第四個(gè)表date_test3(char、datetime時(shí)間)
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,現(xiàn)在我們開(kāi)始做測(cè)試,環(huán)境是php,先向各個(gè)表插入一百萬(wàn)條數(shù)據(jù)。插入的時(shí)候分200次,每次進(jìn)庫(kù)5000條。
表一執(zhí)行記錄:頁(yè)面運(yùn)行時(shí)間: 26.5997889042 秒,插入的時(shí)候發(fā)現(xiàn)一個(gè)有趣的現(xiàn)象:SELECT count( id ) FROM `date_test` WHERE 1 的結(jié)果是100w,而直接select * from `date_test`卻是1,000,374條結(jié)果。(后來(lái)看到這是一個(gè)可能接近的值,請(qǐng)參看MySQL FAQ 3.11)。
表二執(zhí)行記錄:頁(yè)面運(yùn)行時(shí)間: 62.3908278942 秒,這次記錄是1,000,066條。
表三執(zhí)行記錄:頁(yè)面運(yùn)行時(shí)間: 30.2576560974 秒,這次的是1,000,224條。
表四執(zhí)行記錄:頁(yè)面運(yùn)行時(shí)間: 67.5393900871 秒,這次的是:1,000,073條。
現(xiàn)在把四個(gè)表的start_time字段一一加上索引。
測(cè)試四個(gè)表的更新,分別update 100條記錄,并記錄時(shí)間:
表一:頁(yè)面運(yùn)行時(shí)間: 2.62180089951 秒(非定長(zhǎng),int時(shí)間)
表二:頁(yè)面運(yùn)行時(shí)間: 2.5475358963 秒(定長(zhǎng),int時(shí)間)
表三:頁(yè)面運(yùn)行時(shí)間: 2.45077300072 秒(varchar,datetime時(shí)間)
表四:頁(yè)面運(yùn)行時(shí)間: 2.82798409462 秒(char,datetime時(shí)間)
測(cè)試四個(gè)表的讀取,分別select 100條隨機(jī)記錄,以主鍵id為條件查詢(xún),并記錄時(shí)間:
表一:頁(yè)面運(yùn)行時(shí)間: 0.382651090622 秒(非定長(zhǎng),int時(shí)間)
表二:頁(yè)面運(yùn)行時(shí)間: 0.542181015015 秒(定長(zhǎng),int時(shí)間)
表三:頁(yè)面運(yùn)行時(shí)間: 0.334048032761 秒(varchar,datetime時(shí)間)
表四:頁(yè)面運(yùn)行時(shí)間: 0.506206989288 秒(char,datetime時(shí)間)
測(cè)試四個(gè)表的讀取,分別select 10條隨機(jī)記錄,以star_time為條件查詢(xún),并記錄時(shí)間:
表一:頁(yè)面運(yùn)行時(shí)間: 30.1972880363 秒(非定長(zhǎng),int時(shí)間)
表二:頁(yè)面運(yùn)行時(shí)間: 65.1926910877 秒(定長(zhǎng),int時(shí)間)
表三:頁(yè)面運(yùn)行時(shí)間: 39.7210869789 秒(varchar,datetime時(shí)間)
表四:頁(yè)面運(yùn)行時(shí)間: 70.4632740021 秒(char,datetime時(shí)間)
因?yàn)榱勘容^小,所以我們默認(rèn)即使是微小的變化,也是有意義的。
結(jié)論:
大數(shù)據(jù)量下,如果存在大量的select * from table where 時(shí)間>XX這樣的查詢(xún),在MySQL5.1時(shí)使用int換datetime是有意義的。
相關(guān)文章
解析PHP跳出循環(huán)的方法以及continue、break、exit的區(qū)別介紹
本篇文章是對(duì)PHP跳出循環(huán)的方法以及continue、break、exit的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07php基于表單密碼驗(yàn)證與HTTP驗(yàn)證用法實(shí)例
這篇文章主要介紹了php基于表單密碼驗(yàn)證與HTTP驗(yàn)證用法,以實(shí)例形式較為詳細(xì)的分析了表單密碼驗(yàn)證與HTTP驗(yàn)證的原理與相關(guān)注意事項(xiàng),具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01深入理解PHP幾個(gè)算法:PHP冒泡、PHP二分法、PHP求素?cái)?shù)、PHP乘法表
本篇文章是對(duì)PHP冒泡、PHP二分法、PHP求素?cái)?shù)、PHP乘法表進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06php getimagesize 上傳圖片的長(zhǎng)度和寬度檢測(cè)代碼
getimagesize — 取得圖像大小2010-05-05刪除數(shù)組元素實(shí)用的PHP數(shù)組函數(shù)
php之從數(shù)組中刪除空白的元素(包括只有空白字符的元素)將一個(gè)二維數(shù)組轉(zhuǎn)換為 hashmap2008-08-08php解決crontab定時(shí)任務(wù)不能寫(xiě)入文件問(wèn)題的方法分析
這篇文章主要介紹了php解決crontab定時(shí)任務(wù)不能寫(xiě)入文件問(wèn)題的方法,結(jié)合實(shí)例形式分析了crontab定時(shí)任務(wù)無(wú)法正常執(zhí)行的原因與解決方法,需要的朋友可以參考下2019-09-09用php+javascript實(shí)現(xiàn)二級(jí)級(jí)聯(lián)菜單的制作
二級(jí)級(jí)聯(lián)菜單在我去年的時(shí)候就用asp+js做過(guò),而現(xiàn)在忽然拿出來(lái)再做的時(shí)候我發(fā)現(xiàn)我忘記了,而且原來(lái)用asp寫(xiě)的程序都找不到了,真暈[emot]sweat[/emot],于是到網(wǎng)上搜,找了半天,我發(fā)現(xiàn)網(wǎng)上的寫(xiě)法各異,而且都特別復(fù)雜,這么一個(gè)二級(jí)級(jí)聯(lián)菜單,有必要弄這么復(fù)雜嗎?于是自己想重新寫(xiě)一個(gè)簡(jiǎn)單的。在經(jīng)過(guò)半個(gè)小時(shí)左右的思考后,我完成了二級(jí)級(jí)聯(lián)菜單的設(shè)計(jì)和制作。2008-05-05