MySQL數(shù)據(jù)庫(kù)時(shí)間類(lèi)型的物理存儲(chǔ)
MySQL數(shù)據(jù)庫(kù)時(shí)間類(lèi)型的物理存儲(chǔ)的相關(guān)知識(shí)是本文我們主要要介紹的內(nèi)容,接下來(lái)就讓我們一起來(lái)了解一下這部分內(nèi)容吧。
1.timestamp類(lèi)型
在行數(shù)據(jù)中記錄的是時(shí)間戳,四個(gè)字節(jié),將四個(gè)字節(jié)的數(shù)據(jù)轉(zhuǎn)換為整數(shù)就是從1970開(kāi)始的秒數(shù)值
2.date類(lèi)型
存儲(chǔ)3個(gè)字節(jié),例如,若行中記錄的是:
- (gdb) p buf[30]
- $4 = 33 '!'
- (gdb) p buf[31]
- $5 = -73 '�'
- (gdb) p buf[32]
- $6 = 15 '\017'
表示為三個(gè)字節(jié)的二進(jìn)制:
00001111 10110111 00100001
其中,1-5位表示日期,6-9位表示月份,剩余的表示年份,因此上述date類(lèi)型可轉(zhuǎn)換為2011-09-01
3.year類(lèi)型
記錄年份,用一個(gè)字節(jié)記錄,從1900年開(kāi)始
例如
- (gdb) p buf[33]
- $7 = 112 'p'
表示112+1900 = 2012年
4.datetime
8個(gè)字節(jié)表示,例如輸入為:2011-08-27 19:32:46
- (gdb) p buf[30]
- $122 = -98 '\236'
- (gdb) p buf[31]
- $123 = 3 '\003'
- (gdb) p buf[32]
- $124 = -74 '�'
- (gdb) p buf[33]
- $125 = 106 'j'
- (gdb) p buf[34]
- $126 = 74 'J'
- (gdb) p buf[35]
- $127 = 18 '\022'
- (gdb) p buf[36]
- $128 = 0 '\0'
- (gdb) p buf[37]
- $129 = 0 '\0'
那么轉(zhuǎn)換為(256-98) + 3*256 + (256-74) * 256 * 256 + 106 * 256 * 256 * 256 + 74 * 256 * 256 * 256*256 + 18 * 256 * 256 * 256 * 256*256
計(jì)算結(jié)果為:20110827193246, 與輸入的日期相對(duì)應(yīng)!
關(guān)于MySQL數(shù)據(jù)庫(kù)時(shí)間類(lèi)型的物理存儲(chǔ)的相關(guān)知識(shí)就介紹到這里了,希望本次的介紹能夠?qū)δ兴斋@!
【編輯推薦】






