MySQL 日期时间

数据类型

MySQL中有5中表示时间值的数据类型,分别是DATETIMEYEARDATETIMETIMESTAMP

  • DATE 日期值,格式为YYYY-MM-DD,大小3字节,范围从1000-01-01到9999-12-31。
  • TIME 时间值或持续时间,格式为HH:MM:SS,大小3字节,范围从-838:59:59到838:59:59。
  • YEAR 年份值,格式为YYYY,大小1字节,范围从1901到2155。
  • DATETIME 混合日期和时间值,格式为YYYY-MM-DD HH:MM:SS,大小8字节,范围从1000-01-01 00:00:00到9999-12-31 23:59:59。
  • TIMESTAMP 混合日期和时间值的时间戳,格式为YYYYMMDD HHMMSS,大小4字节,范围从1970-01-01 00:00:00到2037年。

注意:TIMESTAMP类型拥有专有的自动更新特性

时间与字符串转换

  • DATE_FORMATTIME_FORMAT日期时间转换函数可以将一个日期或时间转换成各种字符串格式。
  • DATE_FORMATTIME_FORMAT实际是STR_TO_DATE函数的逆转换

STR_TO_DATE 字符串转时间

  • STR_TO_DATE转换函数可以将杂乱无章的字符串转换为日期格式,同时也可以用来转换时间。
STR_TO_DATE(str, format)

例如:

SELECT STR_TO_DATE('2019-05-14', '%Y-%m-%d %H:%i:%s')
-- 2019-05-14 00:00:00

DATE_FORMAT 日期格式化

DATE_FORMAT(date, format)

例如:

SELECT DATE_FORMAT(NOW(), "%Y-%m-%d %H:%i:%s")
-- 2019-05-14 16:04:20

TIME_FORMAT 时间格式化

TIME_FORMAT(time, format)

例如:

SELECT TIME_FORMAT(NOW(),'%H:%i:%s')
-- 17:24:44

日期时间格式化字符串

日期格式化取值范围

  • %Y 四位数字表示的年份,如2019...
  • %y 两位数字表示的年份,如19...

  • %M 英文表示的月份,如January、February...
  • %b 英文缩写表示的月份,如Jan,Feb...
  • %m 两位数字表示的月份,如01,02,03...
  • %c 数字表示的月份,如1,2,3...

  • %d 两位数字表示的月中天数,如 01, 02...
  • %e 数字表示的月中天数,如1,2...
  • %D 英文后缀表示的月中天数,如1st, 2st...
  • %j 以三位数字表示的年中天数,如001, 002...

  • %W 英文全程表示的一周中每一天的名称,如Sunday, Monday...
  • %a 英文缩写表示的一周中每一天的名称,如Sun, Mon...
  • %w 数字形式表示一周中每一天,周日为0,周一为1,依次递增。
  • %U 数字形式表示的周数,周日为第一天。
  • %u 数字形式表示的周数,周一为第一天。

小时

  • %H 24小时制两位数形式表示的小时,如00, 01,...,23
  • %h 12小时制两位数形式表示的小时,如01, 02,...,12
  • %k 24小时制数字形式表示的小时,如0,1,2,...,23
  • %l 12小时制数字形式表示的小时,如0,1,2,...,12
  • %T 24小时制的时间形式HH:mm:ss
  • %r 12小时制时间形式hh:mm:ss AM/PM
  • %p AM上午或PM下午

分钟

  • %i 两位数字形式表示的分钟,如00,01,02,...,59
  • %I

秒数

  • %S 两位数字形式表示的秒数,如00,01,02,...,59
  • %s 两位数字形式表示的秒数,如00,01,02,...,59

时间戳转换

UNIX_TIMESTAMP

  • UNIX_TIMESTAMP() 获取当前时间戳
SELECT UNIX_TIMESTAMP()
-- 1557826503
  • UNIX_TIMESTAMP(date) 时间转时间戳
SELECT UNIX_TIMESTAMP(NOW())
-- 1557825088
  • UNIX_TIMESTAMP(str) 字符串转时间戳

例如:将字符串的日期转换为时间戳

SELECT UNIX_TIMESTAMP('2019-05-14')
-- 1557763200

FROM_UNIXTIME

  • FROM_UNIXTIME(unix_timestamp) 时间戳转字符串
SELECT FROM_UNIXTIME(1557763200)
-- 2019-05-14 00:00:00
  • FROM_UNIXTIME(unix_timestamp, format) 时间戳转字符串
SELECT FROM_UNIXTIME(1557763200, '%Y-%m-%d %H:%i:%s')
-- 2019-05-14 00:00:00

拼凑日期时间

  • MAKEDATE(year, dayofyear)
  • MAKETIME(hour, minute, second)

天数转换

  • TO_DAYS(date) 日期转换为天数
  • FROM_DAYS(days) 天数转换为日期

日期计算

DATE_SUB

DATE_SUB(date,INTERVAL expr unit)

当前日期时间

-- 2019-05-14 18:07:33
SELECT NOW()

计算年份

-- 今年 2019
YEAR(NOW()) 
-- 去年,前一年 2018
YEAR(DATE_SUB(NOW(), INTERVAL 1 YEAR))
-- 明年,后一年 2020
YEAR(DATE_SUB(NOW(), INTERVAL -1 YEAR))

计算月份

-- 当前月 5
MONTH(NOW())
-- 上个月 4
MONTH(DATE_SUB(NOW(),INTERVAL 1 MONTH))
-- 下个月 6
MONTH(DATE_SUB(NOW(),INTERVAL -1 MONTH))

计算天数

-- 月中天数 14
DAY(DATE_SUB(NOW(), INTERVAL 0 DAY))
-- 昨天:前一天 13
DAY(DATE_SUB(NOW(), INTERVAL 1 DAY))
-- 明天:后一天 15
DAY(DATE_SUB(NOW(), INTERVAL -1 DAY))

计算小时

-- 当前小时数 18
HOUR(DATE_SUB(NOW(), INTERVAL 0 HOUR))
-- 前一小时 17
HOUR(DATE_SUB(NOW(), INTERVAL 1 HOUR))
-- 后一小时 19
HOUR(DATE_SUB(NOW(), INTERVAL -1 HOUR))

计算分钟

-- 当前分钟数
MINUTE(DATE_SUB(NOW(), INTERVAL 0 MINUTE))
-- 30分钟前的分钟数
MINUTE(DATE_SUB(NOW(), INTERVAL 30 MINUTE))
-- 30分钟后的分钟数
MINUTE(DATE_SUB(NOW(), INTERVAL -30 MINUTE))

日期查询

查询游戏今日登录用户数

SELECT 
COUNT(1) AS cnt 
FROM game_user
 WHERE 1=1 
AND TO_DAYS(NOW()) = TO_DAYS(FROM_UNIXTIME(logintime))

查询游戏昨日登录用户数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND TO_DAYS(NOW())-TO_DAYS(FROM_UNIXTIME(logintime)) <= 1

查询游戏最近7天用户登录数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND TO_DAYS(NOW()) - TO_DAYS(FROM_UNIXTIME(logintime)) <= 7
SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= DATE(FROM_UNIXTIME(logintime))

查询游戏本周登录用户数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND YEARWEEK(NOW()) = YEARWEEK(FROM_UNIXTIME(logintime,'%Y-%m-%d'))

查询游戏上周用户登录数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND YEARWEEK(NOW()) - YEARWEEK(FROM_UNIXTIME(logintime,'%Y-%m-%d')) = 1

查询游戏本月登录用户数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND DATE_FORMAT(CURDATE(), '%Y%m') = FROM_UNIXTIME(logintime, '%Y%m')
SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND MONTH(NOW()) - MONTH(FROM_UNIXTIME(logintime)) = 0

查询游戏上月登录用户数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND PERIOD_DIFF(DATE_FORMAT(NOW(),'%Y%m'), FROM_UNIXTIME(logintime, '%Y%m')) = 1
SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND MONTH(NOW()) - MONTH(FROM_UNIXTIME(logintime)) = 1

查询游戏本季度用户登录数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND QUARTER(NOW()) = QUARTER(FROM_UNIXTIME(logintime))
SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND QUARTER(NOW()) - QUARTER(FROM_UNIXTIME(logintime)) = 0

查询游戏上季度用户登录数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND QUARTER(DATE_SUB(NOW(), INTERVAL 1 QUARTER)) = QUARTER(FROM_UNIXTIME(logintime))
SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND QUARTER(NOW()) - QUARTER(FROM_UNIXTIME(logintime)) = 1

查询游戏今年用户登录数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND YEAR(NOW()) - YEAR(FROM_UNIXTIME(logintime)) = 0

查询游戏去年用户登录数

SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND YEAR(NOW()) - YEAR(FROM_UNIXTIME(logintime)) = 1
SELECT 
COUNT(1) AS cnt 
FROM game_user 
WHERE 1=1 
AND YEAR(DATE_SUB(NOW(), INTERVAL 1 YEAR)) = YEAR(FROM_UNIXTIME(logintime))

未完待续...

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352