MySQL數據庫時間類型的物理存儲的相關知識是本文我們主要要介紹的內容,接下來就讓我們一起來了解一下這部分內容吧。
1.timestamp類型
在行數據中記錄的是時間戳,四個字節,將四個字節的數據轉換為整數就是從1970開始的秒數值
2.date類型
存儲3個字節,例如,若行中記錄的是:
- (gdb) p buf[30]
- $4 = 33 '!'
- (gdb) p buf[31]
- $5 = -73 '�'
- (gdb) p buf[32]
- $6 = 15 '\017'
表示為三個字節的二進制:
00001111 10110111 00100001
其中,1-5位表示日期,6-9位表示月份,剩余的表示年份,因此上述date類型可轉換為2011-09-01
3.year類型
記錄年份,用一個字節記錄,從1900年開始
例如
- (gdb) p buf[33]
- $7 = 112 'p'
表示112+1900 = 2012年
4.datetime
8個字節表示,例如輸入為: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'
那麼轉換為(256-98) + 3*256 + (256-74) * 256 * 256 + 106 * 256 * 256 * 256 + 74 * 256 * 256 * 256*256 + 18 * 256 * 256 * 256 * 256*256
計算結果為:20110827193246, 與輸入的日期相對應!
關於MySQL數據庫時間類型的物理存儲的相關知識就介紹到這裡了,希望本次的介紹能夠對您有所收獲!