天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

MySQL時間字段究竟使用INT還是DateTime的說明

今天解析DEDECMS時發(fā)現(xiàn)deder的MYSQL時間字段,都是用

`senddata` int(10) unsigned NOT NULL DEFAULT '0';

隨后又在網上找到這篇文章,看來如果時間字段有參與運算,用int更好,一來檢索時不用在字段上轉換運算,直接用于時間比較!二來如下所述效率也更高。

歸根結底:用int來代替data類型,更高效。

環(huán)境:

Windows XP
php Version 5.2.9
MySQL Server 5.1

第一步、創(chuàng)建一個表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;

第二步、創(chuàng)建第二個表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;

第三步、創(chuàng)建第三個表date_test3(varchar、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;

第四步、創(chuàng)建第四個表date_test3(char、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,現(xiàn)在我們開始做測試,環(huán)境是php,先向各個表插入一百萬條數(shù)據(jù)。插入的時候分200次,每次進庫5000條。

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

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

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

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

現(xiàn)在把四個表的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時間)

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

結論:

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

php技術MySQL時間字段究竟使用INT還是DateTime的說明,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品亚洲欧美一区麻豆 | 92国产精品午夜免费福利视频 | 久久激情影院 | 全黄h全肉细节文在线观看 全黄H全肉细节文短篇 | 久久AV国产麻豆HD真实 | 妈妈的朋友6未删减版完整在线 | 亚洲AV久久无码精品国产网站 | 欧美精品色视频 | 美女大BXXXXN内射 | 久久这里都是精品 | 世界上第一个得抑郁症的人是谁 | 两个女人互添下身高潮自视频 | 色四房播播 | 狠狠狠色丁香婷婷综合久久 | 特黄大片aaaaa毛片 | 精品AV国产一区二区三区 | 怡春院国产精品视频 | 99久久香蕉 | 免费观看高清黄页网址大全 | 国产精品人妻无码免费A片导航 | 教室里的激情电影 | 最近中文字幕MV免费高清在线 | 国产麻豆精品传媒AV国产在线 | 草莓在线观看 | 亚洲国产AV精品一区二区蜜芽 | 99午夜视频 | 亚洲 欧美 日韩 国产 视频 | 欧美大片免费观看 | 精品AV无码一二三区视频 | 95国产欧洲精华液 | 91精品乱码一区二区三区 | 国产久爱青草视频在线观看 | 久久亚洲人成网站 | 美女视频黄a视频全免费网站色窝 | 欧美日韩视频高清一区 | 国产成人精品视频免费大全 | WWW国产色情在线观看APP | 国产精品久久久久久人妻香蕉 | 天天躁日日躁狠狠躁午夜剧场 | 美女张开让男生桶 | 亚洲欧美国产视频 |