MySQL作為一種基于關系型數據庫系統的工具,自然需要支持日期和時間類型的數據。當我們需要在MySQL中創建數據列時,我們可以使用YEAR、MONTH、DAY等數據類型進行定義和存儲。通過這些數據類型,我們可以將日期分割為不同的部分,分別存儲年份、月份、日期等信息。
在MySQL中,YEAR數據類型用于存儲4位數格式的年份。這個數據類型支持的年份范圍從1901年到2155年。MONTH數據類型用于存儲月份,它可以存儲1到12之間的數字。DAY數據類型用于存儲日期,它可以存儲1到31之間的數字。
除了上述三種數據類型,MySQL還支持其他日期和時間相關的數據類型,例如DATETIME、TIMESTAMP、TIME、DATE等。其中,DATETIME用于存儲日期和時間的組合信息,可以存儲的日期范圍為從‘1000-01-01 00:00:00’到‘9999-12-31 23:59:59’。TIMESTAMP也用于存儲日期和時間信息,但是其存儲的日期范圍更小,只能存儲到‘1970-01-01 00:00:01’到‘2038-01-19 03:14:07’之間的時間。時間類型的數據類型TIME用于存儲時間信息,而DATE數據類型則只能存儲年、月、日的日期信息。
CREATE TABLE `test_table` ( `id` INT NOT NULL AUTO_INCREMENT, `year_col` YEAR NOT NULL, `month_col` MONTH NOT NULL, `day_col` DAY NOT NULL, `datetime_col` DATETIME NOT NULL, `timestamp_col` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, `time_col` TIME NOT NULL, `date_col` DATE NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
在上面的SQL語句中,我們創建了一個名為test_table的新表,并定義了包含YEAR、MONTH、DAY、DATETIME、TIMESTAMP、TIME和DATE等不同類型的數據列。這些數據列都是非空數據,而TIMESTAMP數據列在沒有提供默認值的情況下將使用當前的時間戳。經過這樣的定義之后,我們便可以開始按照不同類型的數據進行存儲和讀取等操作。