-->

科技资讯

您的当前位置:首页 > 资讯 > MySQL

mysql函数-时间操作

2019-04-09 14:10:00  来源:admin 点击:627

3、时期时间函数 
dayofweek(date)    
返回日期date是星期几(1=星期天,2=星期一,……7=星期六,odbc标准)  
mysql> select dayofweek('1998-02-03');    
  -> 3    
 
weekday(date)    
返回日期date是星期几(0=星期一,1=星期二,……6= 星期天)。 
  
mysql> select weekday('1997-10-04 22:23:00');    
  -> 5    
mysql> select weekday('1997-11-05');    
  -> 2    
 
dayofmonth(date)    
返回date是一月中的第几日(在1到31范围内)    
mysql> select dayofmonth('1998-02-03');    
  -> 3    
 
dayofyear(date)    
返回date是一年中的第几日(在1到366范围内)    
mysql> select dayofyear('1998-02-03');    
  -> 34    
 
month(date)    
返回date中的月份数值    
mysql> select month('1998-02-03');    
  -> 2    
 
dayname(date)    
返回date是星期几(按英文名返回)  
mysql> select dayname("1998-02-05");    
  -> 'thursday'    
 
monthname(date)    
返回date是几月(按英文名返回)  
mysql> select monthname("1998-02-05");    
  -> 'february'    
 
quarter(date)    
返回date是一年的第几个季度    
mysql> select quarter('98-04-01');    
  -> 2    
 
week(date,first)   
返回date是一年的第几周(first默认值0,first取值1表示周一是
周的开始,0从周日开始)  
mysql> select week('1998-02-20');    
  -> 7    
mysql> select week('1998-02-20',0);    
  -> 7    
mysql> select week('1998-02-20',1);    
  -> 8    
 
year(date)    
返回date的年份(范围在1000到9999)    
mysql> select year('98-02-03');    
  -> 1998    
 
hour(time)    
返回time的小时数(范围是0到23)   
mysql> select hour('10:05:03');    
  -> 10    
 
minute(time)    
返回time的分钟数(范围是0到59)    
mysql> select minute('98-02-03 10:05:03');    
  -> 5    
 
second(time)    
返回time的秒数(范围是0到59)   
mysql> select second('10:05:03');    
  -> 3    
 
period_add(p,n)    
增加n个月到时期p并返回(p的格式yymm或yyyymm)    
mysql> select period_add(9801,2);    
  -> 199803    
 
period_diff(p1,p2)    
返回在时期p1和p2之间月数(p1和p2的格式yymm或yyyymm)  
mysql> select period_diff(9802,199703);    
  -> 11    
 
date_add(date,interval expr type)  
date_sub(date,interval expr type)    
adddate(date,interval expr type)    
subdate(date,interval expr type)  
对日期时间进行加减法运算  
(adddate()和subdate()是date_add()和date_sub()的同义词,也
可以用运算符+和-而不是函数  
date是一个datetime或date值,expr对date进行加减法的一个表
达式字符串type指明表达式expr应该如何被解释  
 [type值 含义 期望的expr格式]:  
 second 秒 seconds    
 minute 分钟 minutes    
 hour 时间 hours    
 day 天 days    
 month 月 months    
 year 年 years    
 minute_second 分钟和秒 "minutes:seconds"    
 hour_minute 小时和分钟 "hours:minutes"    
 day_hour 天和小时 "days hours"    
 year_month 年和月 "years-months"    
 hour_second 小时, 分钟, "hours:minutes:seconds"    
 day_minute 天, 小时, 分钟 "days hours:minutes"    
 day_second 天, 小时, 分钟, 秒 "days
hours:minutes:seconds" 
 expr中允许任何标点做分隔符,如果所有是date值时结果是一个
date值,否则结果是一个datetime值)  
 如果type关键词不完整,则mysql从右端取值,day_second因为缺
少小时分钟等于minute_second)  
 如果增加month、year_month或year,天数大于结果月份的最大天
数则使用最大天数)    
mysql> select "1997-12-31 23:59:59" + interval 1 second;  
 
  -> 1998-01-01 00:00:00    
mysql> select interval 1 day + "1997-12-31";    
  -> 1998-01-01    
mysql> select "1998-01-01" - interval 1 second;    
  -> 1997-12-31 23:59:59    
mysql> select date_add("1997-12-31 23:59:59",interval 1
second);    
  -> 1998-01-01 00:00:00    
mysql> select date_add("1997-12-31 23:59:59",interval 1
day);    
  -> 1998-01-01 23:59:59    
mysql> select date_add("1997-12-31 23:59:59",interval
"1:1" minute_second);    
  -> 1998-01-01 00:01:00    
mysql> select date_sub("1998-01-01 00:00:00",interval "1
1:1:1" day_second);    
  -> 1997-12-30 22:58:59    
mysql> select date_add("1998-01-01 00:00:00", interval "-1
10" day_hour);  
  -> 1997-12-30 14:00:00    
mysql> select date_sub("1998-01-02", interval 31 day);    
  -> 1997-12-02    
mysql> select extract(year from "1999-07-02");    
  -> 1999    
mysql> select extract(year_month from "1999-07-02
01:02:03");    
  -> 199907    
mysql> select extract(day_minute from "1999-07-02
01:02:03");    
  -> 20102    
 
to_days(date)    
返回日期date是西元0年至今多少天(不计算1582年以前)  
mysql> select to_days(950501);    
  -> 728779    
mysql> select to_days('1997-10-07');    
  -> 729669    

© 2024版权所有 水水网

电话:171780793