首頁  >  文章  >  資料庫  >  MySQL中關於datetime、date、time、str之間的轉換與比較

MySQL中關於datetime、date、time、str之間的轉換與比較

WBOY
WBOY轉載
2022-10-08 17:25:482359瀏覽

這篇文章為大家帶來了關於mysql的相關知識,其中主要介紹了關於datatime、data、time、str之間的轉化與比較的相關問題,下面一起來看一下,希望對大家有幫助。

推薦學習:mysql影片教學

#datetime、date、time、str之間的轉換與比較

SELECT NOW(),CURDATE(),CURTIME(),
  -- datetime 转 date time
  NOW(), DATE(NOW()), TIME (NOW()), CONCAT(DATE(NOW()), ' ', TIME (NOW())),
  -- str 转 datetime date time
  str_to_date('2019-04-25 08:50:00', '%Y-%m-%d %H:%i:%s'),DATE('2019-04-25 08:50:00'),TIME ('2019-04-25 08:50:00'),
  str_to_date('2019-04-25 08:50:00', '%Y-%m-%d %T'),
  -- 比较
  NOW() = CONCAT(DATE(NOW()), ' ', TIME (NOW())),
  DATE(NOW()) = '2019-04-25',
  NOW() = DATE(NOW()),
  NOW() = TIME (NOW());
 
-- 获取当前时间的函数
select CURRENT_TIMESTAMP, CURRENT_DATE, CURRENT_TIME;	-- 当前时间
select CURRENT_TIMESTAMP(), CURRENT_DATE(), CURRENT_TIME(), CURDATE(), CURTIME();	-- 当前时间
select now(), sysdate(), SLEEP(3), now(), sysdate();	-- 当前时间
select UTC_TIMESTAMP(), UTC_DATE(), UTC_TIME();	-- UTC时间
select UNIX_TIMESTAMP(), UNIX_TIMESTAMP(now());-- 函数返回连接当前时区内的值(时间戳)
select FROM_UNIXTIME(UNIX_TIMESTAMP(),'%Y-%m-%d %H:%i:%s'); -- 时间戳格式化
select DATE_FORMAT(now(),'%Y-%m-%d %H:%i:%s'); -- 时间格式化

-- ----------------- 补充日期操作
/* 对日期进行 加减(两个函数记一个即可)
DATE_ADD(date,INTERVAL expr type);
DATE_SUB(date,INTERVAL expr type);
type取值:YEAR、MONTH、DAY、HOUR、MINUTE、SECOND、YEAR_MONTH、DAY_SECOND 等等
*/
-- 加1天
select DATE_ADD(now(),INTERVAL 1 DAY), DATE_SUB(now(),INTERVAL -1 DAY);
-- 复合型:加1年1月
select DATE_ADD(now(),INTERVAL '1 1' YEAR_MONTH), DATE_SUB(now(),INTERVAL '-1 -1' YEAR_MONTH);
-- 加1天2时3分4秒
select DATE_ADD('2020-12-23 00:00:00',INTERVAL '1 2:3:4' DAY_SECOND),DATE_SUB('2020-12-23 00:00:00',INTERVAL '-1 -2:-3:-4' DAY_SECOND);

/* 获取两个日期之间的差值(datetime_expr2-datetime_expr1的值)
TIMESTAMPDIFF(unit,datetime_expr1,datetime_expr2)
unit:差值的单位,取值:FRAC_SECOND(低版本不支持)、SECOND、MINUTE、HOUR、DAY、WEEK、MONTH、QUARTER或YEAR
*/
-- 查询两个日期间的差值(单位秒)
select TIMESTAMPDIFF(SECOND,'2020-12-01 00:00:00','2020-12-01 01:01:01');

MySQL日期和時間資料類型(DATE、TIME、 DATETIME、 TIMESTAMP和YEAR

本文基於MySQL 5.7版本。

MySQL中表示時間值的日期和時間資料類型有以下五個:

(1)DATE

(2)TIME

(3)DATETIME

(4)TIMESTAMP

#( 5)YEAR

日期和時間資料類型語法

MySQL允許對TIME、DATETIME和TIMESTAMP使用小數秒,精確度最高可達微秒(6位元小數) 。要定義包含小數秒日期和時間資料類型的列,使用

type_name(fsp),

其中type_name是TIME、DATETIME或TIMESTAMP,而fsp是小數秒精度,fsp的值,如果給定,必須在0 ~ 6之間。值為0表示沒有小數部分。如果省略,預設精度為0。

例如:

CREATE TABLE date_time_test (t TIME(3), dt DATETIME(6), ts TIMESTAMP(0));

Date

支援的範圍'1000-01-01' to '9999-12-31',MySQL以'YYYY-MM-DD'格式顯示Date類型,但允許使用字串或數字將值賦給DATE列。字面常數轉換規則如下:

(1)格式為'YYYY-MM-DD'或'YY-MM-DD'的字串。任何標點字元都可以用作日期部分之間的分隔符號。例如,'2012-12-31'、'2012/12/31'、'2012^12^31'和'2012@12@31'是等價的。

(2)格式為'YYYYMMDD'或'YYMMDD'的沒有分隔符號的字串,只要該字串具有日期的意義。例如,'20070523'和'070523'被解釋為'2007-05-23',但'071332'是非法的(它有無意義的月和日部分),會變成'0000-00-00'。

(3)作為YYYYMMDD或YYMMDD格式的數字,只要該數字作為日期有意義。例如,19830905和830905被解釋為「1983-09-05」。

DATETIME和DATETIME(fsp)

DATETIME類型是Date和Time的組合。支援的範圍從'1000-01-01 00:00:00.000000' 到'9999-12-31 23:59:59.999999'。 MySQL以'YYYY-MM-DD hh:mm:ss[.fraction]'的格式顯示DATETIME類型。但允許使用字串或數字向DATETIME列賦值。字面常數轉換規則如下:

表中的任何TIMESTAMP或DATETIME欄位都可以具有自動初始化和更新屬性。

(1)格式為「YYYY-MM-DD hh:mm:ss」或「YY-MM-DD hh:mm:ss」字串。任何標點字元都可以用作日期部分或時間部分之間的分隔符號。例如,'2012-12-31 11:30:45'、'2012^12^31 11 30 45'、'2012/12/31 11*30*45'和'2012@12@31 11^30^45 '是等價的。

(2)在日期和時間部分和小數秒部分之間識別的唯一分隔符號是小數點。

(3)日期和時間部分可以用T而不是空格分隔。例如,'2012-12-31 11:30:45' '2012-12-31 t11:30:45 '是等價的。

(4)格式為'YYYYMMDDhhmmss'或'YYMMDDhhmmss'無分隔符號的字串,只要該字串具有日期的意義。例如,'20070523091528'和'070523091528'被解釋為'2007-05-23 09:15:28',但'071122129015'是非法的(它有一個無意義的分鐘部分),會變成'00000-0000000 -00 00:00:00'。

(5)YYYYMMDDhhmmss或YYMMDDhhmmss格式的數字,只要該數字作為日期有意義。例如,19830905132800和830905132800被解釋為「1983-09-05 13:28:00」。

TIMESTAMP和TIMESTAMP[(fsp)]

支援的範圍'1970-01-01 00:00:01.000000' UTC to '2038-01-19 03 :14:07.999999' UTC(UTC指的是世界標準時間),TIMESTAMP值儲存為自紀元('1970-01-01 00:00:00' UTC)以來的秒數,但是它不能表示'1970-01 -01 00:00:00',因為這表示從紀元開始的0秒,值0保留用於表示“0000-00-00 00:00:00”,即“零”的TIMESTAMP值。 TIMESTAMP的字面常數同DATETIME。

上面date_time_test表ts欄位是TIMESTAMP,一旦建立後,我們發現ts列預設值為目前TIMESTAMP,而且可自動更新為目前時間戳,如圖: 

支持的范围'1970-01-01 00:00:01.000000' UTC to '2038-01-19 03:14:07.999999' UTC(UTC指的是世界标准时间),TIMESTAMP值存储为自纪元('1970-01-01 00:00:00' UTC)以来的秒数,但是它不能表示'1970-01-01 00:00:00',因为这表示从纪元开始的0秒,值0保留用于表示“0000-00-00 00:00:00”,即“零”的TIMESTAMP值。TIMESTAMP的字面常量同DATETIME。

上面date_time_test表ts列是TIMESTAMP,一旦创建后,我们发现ts列默认值为当前TIMESTAMP,而且可自动更新为当前时间戳,如图:

向date_time_test表中插入一条数据,如下: 

insert date_time_test(t) values('00:00:01');

查看数据,如图:

发现ts列自动更新为插入数据时的时间戳。

更新当前数据,如图:

update date_time_test set t='00:00:02' where t='00:00:01';

再次查看时间戳,如图:

 ts列已经更新为当前时间戳。这和MySQL的系统变量explicit_defaults_for_timestamp有关,

show variables like 'explicit_defaults_for_timestamp';

如图:

explicit_defaults_for_timestamp处于关闭状态,此时,插入数据时,如果ts没有指定值,会被初始化为默认值,更新数据时,ts列同时更新。 explicit_defaults_for_timestamp处于打开状态,不会被初始化为默认,也不具备自动更新为当前时间戳。也可以对TIMESTAMP和DATETIME如下显示定义默认值和自动更新:

CREATE TABLE t1 (
  ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  dt DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);

TIME和TIME(fsp)

支持的范围'-838:59:59.000000' to '838:59:59.000000',MySQL以'hh:mm:ss[.fraction]'格式显示TIME,但允许使用字符串或数字向TIME列赋值。TIME类型这个时间范围表明它不仅可以表示一天的时间,也可以表示经过的时间或两个事件之间的时间间隔。字面常量转换规则如下:

(1)MySQL将带有冒号的TIME值缩写为一天中的时间,例如:'11:12'表示'11:12:00',而不是 '00:11:12';

(2)MySQL将没有冒号的TIME缩写值最右边的两个数字看成秒,例如:'1112'和1112都表示'00:11:12'

(3)在时间部分和小数秒部分之间识别的唯一分隔符是小数点;

(4)默认情况下,位于TIME范围之外但在其他方面有效的值将被裁剪到该范围中最近的端点。例如,'-850:00:00'和'850:00:00'会转换为'-838:59:59'和'838:59:59'。无效的TIME值将被转换为“00:00:00”。注意,由于'00:00:00'本身是一个有效的TIME值,因此无法从存储在表中的'00:00:00'值判断原始值是'00:00:00'还是无效的。

YEAR和YEAR(4)

支持的范围1901到2155,或者0000。MySQL以YYYY格式显示YEAR。但允许使用字符串或数字向YEAR列赋值。

SUM()和AVG()聚合函数不能处理时间值。要解决这个问题,请将其转换为数字,然后执行聚合操作,最后将其转换回时间值。例子:

SELECT SEC_TO_TIME(SUM(TIME_TO_SEC(time_col))) FROM tbl_name;
SELECT FROM_DAYS(SUM(TO_DAYS(date_col))) FROM tbl_name;

YEAR接受如下格式的输入:

(1)4位字符串'1901' 到 '2155';

(2)4位数字1901 到 2155;

(3)1或者2位字符串'0' 到 '99',MySQL将'0'到'69'转化为2000到2069,将'70'到'99'转化为1970到1999;

(4)1或者2位数字0到 99,MySQL将1到69转换为YEAR值2001到2069,将70到99转化为YEAR值1970到1999,0转化为YEAR值0000。

注:

如果没有启用strict SQL模式,MySQL会将无效的YEAR值转换为0000。在严格SQL模式下,试图插入无效的YEAR值将产生错误。

总结如下:

##0~60~60顯示格式YYYY-MM-DD#hh:mm:ss[.fraction]YYYY-MM-DD hh:mm:ss[.fraction]YYYY-MM-DD hh:mm:ss[.fraction]YYYY賦值允許使用符合格式的字串或數字賦值允許使用符合格式的字串或數字賦值允許使用符合格式的字符字串或數字賦值允許使用符合格式的字串或數字賦值允許使用符合格式的字串或數字賦值小數位分隔符號無只辨識小數點.只辨識小數點.只辨識小數點.無#日期分隔符號任何標點無#任何標點任何標點無時間分隔符號無任何標點任何標點任何標點無無效值處理(strict mode關閉狀態)
  DATE TIME DATETIME TIMESTAMP YEAR
取值范围

'1000-01-01'

'9999-12-31'

'-838:59:59.000000'

'838:59:59.000000'

'1000-01-01 00:00:00.000000' 到

'9999-12-31 23:59:59.999999'

'1970-01-01 00:00:01.000000' UTC to

'2038-01-19 03:14:07.999999' UTC

1901

2155

或者0000

小數位精確度 0 0~6
#轉換為

0000-00-00


####轉換為######0000-00-00 00:00:00############轉換為######0000-00-00 00:00:00############轉換為######00:00:00#########轉換為0000######### #######推薦學習:###mysql影片教學##########

以上是MySQL中關於datetime、date、time、str之間的轉換與比較的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jb51.net。如有侵權,請聯絡admin@php.cn刪除