我们如何忽略 MySQL DATEDIFF() 函数返回的负值?

众所周知,DATEDIFF() 函数用于获取两个日期之间的天数差。因此,它也很可能返回负值。

mysql> select * from differ;
+------------+-------------+
| OrderDate  | WorkingDate |
+------------+-------------+
| 2017-10-22 | 2017-10-29  |
| 2017-10-25 | 2017-10-30  |
| 2017-10-25 | 2017-11-30  |
+------------+-------------+
3 rows in set (0.00 sec)
登录后复制

以上查询将返回表“differ”中的值。现在,如果有人想要获取 OrderDate 和workingDate 之间的差异,那么输出将为负数,如下所示 -

mysql> Select DATEDIFF(OrderDate, WorkingDate)AS 'DIFFERENCE IN DAYS' from differ;
+--------------------+
| DIFFERENCE IN DAYS |
+--------------------+
|                 -7 |
|                 -5 |
|                -36 |
+--------------------+
3 rows in set (0.00 sec)
登录后复制

但是我们可以使用 MySQL ABS() 函数来忽略这些负值,具体操作如下 -

mysql> Select ABS(DATEDIFF(OrderDate, WorkingDate))AS 'DIFFERENCE IN DAYS' from differ;
+--------------------+
| DIFFERENCE IN DAYS |
+--------------------+
|                  7 |
|                  5 |
|                 36 |
+--------------------+
3 rows in set (0.00 sec)
登录后复制

以上就是我们如何忽略 MySQL DATEDIFF() 函数返回的负值?的详细内容,转载自php中文网

点赞(246) 打赏

评论列表 共有 0 条评论

暂无评论

微信小程序

微信扫一扫体验

立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部