添加指定间隔的日期
- Date_add()
Next_day()取周末的函数
- Next_day(date_add(dt,-1),’sunday’) as dt (hive中可用,mysql中不可用)
取当前日期所在周的周日(统计周一到周日的数据可以用这个函数)
- SELECT DATE_SUB('2017/5/29',INTERVAL WEEKDAY('2017/5/29')-6 DAY)
取当前日期所在周的周一
- SELECT DATE_ADD('2017/5/29',INTERVAL WEEKDAY('2017/5/29') DAY);
取当前日期上一周的周日
- SELECT DATE_SUB('2017/5/29', INTERVAL WEEKDAY('2017/5/29')+1 DAY);
显示当前时间
- select now()
取上个月的最后一天
- Add_months(‘2017-11-30’,-1) as date 取上个月的最后一天
取当月的第一天
- select date_add('2017-05-21', interval - day('2017-05-21') + 1 day)
取上个月的数据
- select date_sub('2017-05-31', interval 1 month)
date_format()规定日期输出格式
- select date_format('2017-05-29','%w')
可是使用的格式 | 表述 |
---|---|
%a | 缩写星期名 |
%b | 缩写月名 |
%c | 月,数值 |
%D | 带有英文前缀的月中的天 |
%d | 月的天,数值(00-31) |
%e | 月的天,数值(0-31) |
%f | 微秒 |
%H | 小时 (00-23) |
%h | 小时 (01-12) |
%I | 小时 (01-12) |
%i | 分钟,数值(00-59) |
%j | 年的天 (001-366) |
%k | 小时 (0-23) |
%l | 小时 (1-12) |
%M | 月名 |
%m | 月,数值(00-12) |
%p | AM 或 PM |
%r | 时间,12-小时(hh:mm:ss AM 或 PM) |
%S | 秒(00-59) |
%s | 秒(00-59) |
%T | 时间, 24-小时 (hh:mm:ss) |
%U | 周 (00-53) 星期日是一周的第一天 |
%u | 周 (00-53) 星期一是一周的第一天 |
%V | 周 (01-53) 星期日是一周的第一天,与 %X 使用 |
%v | 周 (01-53) 星期一是一周的第一天,与 %x 使用 |
%W | 星期名 |
%w | 周的天 (0=星期日, 6=星期六) |
%X | 年,其中的星期日是周的第一天,4 位,与 %V 使用 |
%x | 年,其中的星期一是周的第一天,4 位,与 %v 使用 |
%Y | 年,4 位 |
%y | 年,2 位 |
weekday()显示的一周是从周一开始周日结束,其中周一为0,周日为6
- select weekday('2017-05-29')
dayofweek()显示的一周是从周日开始周六结束,其中周日为1,周六为7
- select dayofweek('2017-05-27')
随机产生某一月的日期
- select CONCAT(2017,'-',6,'-',FLOOR(1 + (RAND() * 30))) 6月随机日期
- select FLOOR(1 + (RAND() * 30)) 随机产生1到30的随机函数
网友评论