2011年4月16日 星期六

MySQL5.1 DataType 日期 (Date)

日期
資料名稱byte數值範圍格式說明
DATE 3'1000-01-01'到'9999-12-31''YYYY-MM-DD'日期:允許使用字串或數字為DATE分配值。
DATETIME 8'1000-01-01 00:00:00'到'9999-12-31 23:59:59''YYYY-MM-DD HH:MM:SS'日期和時間的組合:
允許使用字串或數字為DATETIME分配值。
TIMESTAMP(M) 4'1970-01-01 00:00:00'到2037年'YYYY-MM-DD
HH:MM:SS'
時間戳記:TIMESTAMP用於INSERT或UPDATE操作時記錄日期和時間。如果你不分配一個值,表中的第一個TIMESTAMP列自動設置為最近操作的日期和時間。也可以通過分配一個NULL值,將TIMESTAMP列設置為當前的日期和時間。

TIMESTAMP值返回後顯示為'YYYY-MM-DD HH:MM:SS'格式的字符串,顯示寬度固定為19個字符。如果想要獲得數字值,應在TIMESTAMP 列添加+0。
註釋:MySQL 4.1以前使用的TIMESTAMP格式在MySQL 5.1中不支持。
TIME 3'-838:59:59'到'838:59:59''HH:MM:SS' 時間:MySQL以'HH:MM:SS'格式顯示TIME值,但允許使用字串或數字為TIME列分配值。
 YEAR (2|4) 1二位:70到69(1970~2069)。

四位:1901到2155和0000。
YYYY兩位或四位格式的年。預設是四位格式。在四位格式中,允許的值是1901到2155和0000。在兩位格式中,允許的值是70到69,表示從1970年到2069年。 MySQL以YYYY 格式顯示YEAR值,但允許使用字串或數字為YEAR列分配值。

引用與參考資料:
MySQL官方文件

MySQL5.1 DataType 整數與浮點數

說明:
  • M:要顯示的位數,最大有效範圍是255。
  • D:要顯示的小數位數,最大可能的值是30,但是應該不大於M-2。
  • M和D若省略,則會根據計算機硬體來決定。單精度精確約7位小數。
  • 數值列指定ZEROFILL,MySQL會自動為該列加上UNSIGNED屬性。
  • ZEROFILL,自動填0,若有個int(4)資料型態,若填入一個數值1那他會變成0001。
  • UNSIGNED:表示無號數型態。
  • 如果指定UNSIGNED,不允許負值。
數值:
整數
資料名稱bit數值範圍選項說明
TINYINT (M)8有號:-128~127
無號:0~255
UNSIGNED、
ZEROFILL
SMALLINT(M) 16有號:-32768~32767
無號:0~65535
UNSIGNED、ZEROFILL
MEDIUMINT(M) 24有號:-8388608~8388607
無號:0~16777215
UNSIGNED、ZEROFILL
INT(M)32有號:-2147483648~2147483647
無號:0~4294967295
UNSIGNED、ZEROFILL
INTEGER(M)32有號:-2147483648~2147483647
無號:0~4294967295
UNSIGNED、ZEROFILL
BIGINT[(M)] 64有號:-9223372036854775808~9223372036854775807
無號:0~18446744073709551615
UNSIGNED、ZEROFILL


浮點數
資料名稱bit數值範圍選項說明
 FLOAT (M,D)32-3.402823466E+38到-1.175494351E-38、0和1.175494351E-38到3.402823466E+38。 UNSIGNED、ZEROFILL單精度浮點數
DOUBLE (M,D)64-1.7976931348623157E+308到-2.2250738585072014E-308、0和2.2250738585072014E-308到 1.7976931348623157E+308。 UNSIGNED、ZEROFILL雙精度浮點數
DOUBLE PRECISION(M,D) 64 UNSIGNED、ZEROFILLDOUBLE同義詞
REAL(M,D) 32 UNSIGNED、ZEROFILLFLOAT同義詞
FLOAT(p)

 UNSIGNED、ZEROFILL
p表示精度(以位數表示),但MySQL只使用該值來確定是否結果列的資料型態為FLOAT或DOUBLE。如果p值是0~24,資料型態將為沒有M或D值得FLOAT。如果p值是25~53,則資料型態將為沒有M或D值得DOUBLE。
DECIMAL(M,D) UNSIGNED、ZEROFILL壓縮的“嚴格”定點數。 M是小數位數(精度)的總數,D是小數點(標度)後面的位數。小數點和(負數)的'-'符號不包括在M中。如果D是0,則值沒有小數點或分數部分。 DECIMAL整數最大位數(M)為65。支持的十進制數的最大位數(D)是30。如果D被省略, 預設是0。如果M被省略, 預設是10。
DEC(M,D) UNSIGNED、ZEROFILLDECIMAL的同義詞
NUMERIC(M,D) UNSIGNED、ZEROFILLDECIMAL的同義詞
FIXED(M,D)  UNSIGNED、ZEROFILL
FIXED同義詞適用於與其它服務器的兼容性。



參考資料:
http://dev.mysql.com/doc/refman/5.1/zh/column-types.html#choosing-types