Mysql中时间加减和比较大小的方法
来源:互联网 发布:网络交换机与PLC通讯 编辑:程序博客网 时间:2024/05/16 18:33
在Oracle中使用时间函数to_date习惯了,在Oracle中时间的加减也非常简单,直接加减即可。在Mysql中时间的函数很多,非常自由。
在项目中经常用到的就是时间的加减。
比如60天前,Oracle中直接就是sysdate-60,Mysql中就不行。
对时间加减的函数是
加ADDDATE(),减SUBDATE();
select SUBDATE(now(),interval 60 day); 60天前的时间
select ADDDATE(now(),interval 60 day); 60天后的时间
在Oracle中经常用到trunc(sysdate,'D'),截取到天或者到小时。
在Mysql中可以用date_format()来代替。返回的是时间格式的字符串,也是时间
在Mysql中只要符合时间格式的字符串就可以当做Date类型。
取今天时间到天,
mysql> select DATE_FORMAT(now(),'%Y%m%d');
+-----------------------------+
| DATE_FORMAT(now(),'%Y%m%d') |
+-----------------------------+
| 20100611 |
+-----------------------------+
1 row in set (0.00 sec)
取到小时。
mysql> select DATE_FORMAT(now(),'%Y%m%d%H');
+-------------------------------+
| DATE_FORMAT(now(),'%Y%m%d%H') |
+-------------------------------+
| 2010061121 |
+-------------------------------+
1 row in set (0.00 sec)
Mysql中直接比较时间大小也是不能用>或<
只能转换成数字来比较大小。
如果比较天的大小,1号小于2号。需要转换成到现在为止的天数。用到的是to_days(),
mysql> select to_days('20100602');
+---------------------+
| to_days('20100602') |
+---------------------+
| 734290 |
+---------------------+
1 row in set (0.00 sec)
mysql> select to_days('20100603');
+---------------------+
| to_days('20100603') |
+---------------------+
| 734291 |
+---------------------+
1 row in set (0.00 sec)
如果时间的比较很精确,精确到时秒分就需要转换成UNIX_TIMESTAMP,换算成毫秒值来比较大小。
mysql> select UNIX_TIMESTAMP('201006021700');
+--------------------------------+
| UNIX_TIMESTAMP('201006021700') |
+--------------------------------+
| 1601921820 |
+--------------------------------+
1 row in set (0.00 sec)
mysql> select UNIX_TIMESTAMP('201006021800');
+--------------------------------+
| UNIX_TIMESTAMP('201006021800') |
+--------------------------------+
| 1601921880 |
+--------------------------------+
1 row in set (0.00 sec)
在项目中经常用到的就是时间的加减。
比如60天前,Oracle中直接就是sysdate-60,Mysql中就不行。
对时间加减的函数是
加ADDDATE(),减SUBDATE();
select SUBDATE(now(),interval 60 day); 60天前的时间
select ADDDATE(now(),interval 60 day); 60天后的时间
在Oracle中经常用到trunc(sysdate,'D'),截取到天或者到小时。
在Mysql中可以用date_format()来代替。返回的是时间格式的字符串,也是时间
在Mysql中只要符合时间格式的字符串就可以当做Date类型。
取今天时间到天,
mysql> select DATE_FORMAT(now(),'%Y%m%d');
+-----------------------------+
| DATE_FORMAT(now(),'%Y%m%d') |
+-----------------------------+
| 20100611 |
+-----------------------------+
1 row in set (0.00 sec)
取到小时。
mysql> select DATE_FORMAT(now(),'%Y%m%d%H');
+-------------------------------+
| DATE_FORMAT(now(),'%Y%m%d%H') |
+-------------------------------+
| 2010061121 |
+-------------------------------+
1 row in set (0.00 sec)
Mysql中直接比较时间大小也是不能用>或<
只能转换成数字来比较大小。
如果比较天的大小,1号小于2号。需要转换成到现在为止的天数。用到的是to_days(),
mysql> select to_days('20100602');
+---------------------+
| to_days('20100602') |
+---------------------+
| 734290 |
+---------------------+
1 row in set (0.00 sec)
mysql> select to_days('20100603');
+---------------------+
| to_days('20100603') |
+---------------------+
| 734291 |
+---------------------+
1 row in set (0.00 sec)
如果时间的比较很精确,精确到时秒分就需要转换成UNIX_TIMESTAMP,换算成毫秒值来比较大小。
mysql> select UNIX_TIMESTAMP('201006021700');
+--------------------------------+
| UNIX_TIMESTAMP('201006021700') |
+--------------------------------+
| 1601921820 |
+--------------------------------+
1 row in set (0.00 sec)
mysql> select UNIX_TIMESTAMP('201006021800');
+--------------------------------+
| UNIX_TIMESTAMP('201006021800') |
+--------------------------------+
| 1601921880 |
+--------------------------------+
1 row in set (0.00 sec)
0 0
- Mysql中时间加减和比较大小的方法
- Mysql中时间加减和比较大小的方法
- Mysql的时间运算和比较大小的方法
- js计算时间加减及有关时间大小的比较
- C#中时间大小的比较方法
- Java中时间加减的比较
- Struts2中在页面中比较时间大小的方法
- MySql中实现时间比较的方法
- mysql和sql时间 字段比较大小的问题
- Oracle中日期时间的操作比较和加减
- Oracle数据库中日期时间的操作比较和加减
- Oracle中日期时间的操作比较和加减
- Javascript中比较两个时间的大小
- js中比较时间的大小
- 比较两个时间的大小和时间差
- 比较两个时间的大小和时间差
- 时间的转换和比较大小
- SQL中时间的加减
- IOS中的基础动画CABasicAnimation的运用指南
- 使用 Spring Boot 快速构建 Spring 框架应用
- Android5.0L下因sensorservice crash导致systemserver重启的另外一种场景分析
- cf451E Devu and Flowers 卢卡斯定理+容斥定理
- Leetcode|Populating Next Right Pointers in Each Node
- Mysql中时间加减和比较大小的方法
- hdu 2871 Memory Control(成段更新,区间合并)
- php soap实例讲解
- 2. CSS 结构
- 屏蔽/禁止双击选中文字
- 求一个整形数组的最大元素
- zookeeper 存储之文件格式分析
- Hibernate 的HQL,QBC 查询语言
- QT简介