当前位置: 首页 > 图文教程 > 数据库 > MYSQL > mysql的日期和时间函数

MYSQL
MySQL代码如何在 Windows环境下编译
MYSQL出错代码列表
mysql 5.0存储过程学习总结
迅速帮你解决 SQL Server 日志满问题
SQL Server 2005 中能够使用 Try...Catch语句
启动SQL SERVER时自动执行存储过程
无法在SQL 2005系统数据库中执行的T-SQL语句(XML处理)
MySQL关系数据库系统IF查询处理远程拒绝服务漏洞
SQL Server 用户自定义的数据库修复
运行SQL Server的计算机之间移动数据库
jsp从数据库取得数据作为下拉菜单选项的实现
sql server2005 jdbc解决自动增长列统一处理问题纪实
使你的 SQL 语句完全优化
动态网页编程中优化数据库注意的十大原则
SQL Server 2000数据库中如何重建索引
mysql全文搜索索引的字段提高搜索效率
轻松八句话 教会你完全搞定MySQL数据库
MySQL数据库中数据库移植中的乱码问题
分析数据库备份过程中九种可能出现的情况
对付ARP欺骗攻击16a.us病毒的解决方案

MYSQL 中的 mysql的日期和时间函数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 76 ::
收藏到网摘: n/a

mysql的日期和时间函数 
这里是一个使用日期函数的例子。下面的查询选择所有 date_col 值在最后 30 天内的记录。  
mysql> SELECT something FROM tbl_name 
           WHERE TO_DAYS(NOW()) - TO_DAYS(date_col) <= 30; 

DAYOFWEEK(date)  
返回 date 的星期索引(1 = Sunday, 2 = Monday, ... 7 = Saturday)。索引值符合 ODBC 的标准。  
mysql> SELECT DAYOFWEEK(’1998-02-03’); 
        -> 3 

WEEKDAY(date)  
返回 date 的星期索引(0 = Monday, 1 = Tuesday, ... 6 = Sunday):  
mysql> SELECT WEEKDAY(’1998-02-03 22:23:00’); 
        -> 1 
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 中的月份,范围为 1 到 12:  
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 在一年中的季度,范围为 1 到 4:  
mysql> SELECT QUARTER(’98-04-01’); 
        -> 2 

WEEK(date)  
WEEK(date,first)  
对于星期日是一周中的第一天的场合,如果函数只有一个参数调用,返回 date 为一年的第几周,返回值范围为 0 到 53 (是的,可能有第 53 周的开始)。两个参数形式的 WEEK() 允许你指定一周是否以星期日或星期一开始,以及返回值为 0-53 还是 1-52。 这里的一个表显示第二个参数是如何工作的: 
 
值     含义
 0      一周以星期日开始,返回值范围为 0-53 
 1      一周以星期一开始,返回值范围为 0-53 
 2      一周以星期日开始,返回值范围为 1-53 
 3      一周以星期一开始,返回值范围为 1-53 (ISO 8601) 


mysql> SELECT WEEK(’1998-02-20’);
        -> 7
mysql> SELECT WEEK(’1998-02-20’,0);
        -> 7
mysql> SELECT WEEK(’1998-02-20’,1);
        -> 8
mysql> SELECT WEEK(’1998-12-31’,1);
        -> 53

注意,在版本 4.0 中,WEEK(#,0) 被更改为匹配 USA 历法。 注意,如果一周是上一年的最后一周,当你没有使用 2 或&