个人笔记: 努力奋斗
日期计算
MySQL 提供了多个可用于执行日期计算的函数,例如计算年龄或提取部分日期。
要确定每只宠物的年龄,请使用该 TIMESTAMPDIFF()
函数。它的参数是您想要表示结果的单位,以及要求差的两个日期。以下查询显示每只宠物的出生日期、当前日期和年龄(以岁为单位)。别名age用于使最终输出列标签更有意义。
mysql> SELECT name, birth, CURDATE(),
TIMESTAMPDIFF(YEAR,birth,CURDATE()) AS age
FROM pet;
+----------+------------+------------+------+
| name | birth | CURDATE() | age |
+----------+------------+------------+------+
| Fluffy | 1993-02-04 | 2003-08-19 | 10 |
| Claws | 1994-03-17 | 2003-08-19 | 9 |
| Buffy | 1989-05-13 | 2003-08-19 | 14 |
| Fang | 1990-08-27 | 2003-08-19 | 12 |
| Bowser | 1989-08-31 | 2003-08-19 | 13 |
| Chirpy | 1998-09-11 | 2003-08-19 | 4 |
| Whistler | 1997-12-09 | 2003-08-19 | 5 |
| Slim | 1996-04-29 | 2003-08-19 | 7 |
| Puffball | 1999-03-30 | 2003-08-19 | 4 |
+----------+------------+------------+------+
该查询有效,但如果按某种顺序显示行,则可以更轻松地扫描结果。ORDER BY name这可以通过添加一个子句来按名称对输出进行排序来 完成:
mysql> SELECT name, birth, CURDATE(),
TIMESTAMPDIFF(YEAR,birth,CURDATE()) AS age
FROM pet ORDER BY name;
+----------+------------+------------+------+
| name | birth | CURDATE() | age |
+----------+------------+------------+------+
| Bowser | 1989-08-31 | 2003-08-19 | 13 |
| Buffy | 1989-05-13 | 2003-08-19 | 14 |
| Chirpy | 1998-09-11 | 2003-08-19 | 4 |
| Claws | 1994-03-17 | 2003-08-19 | 9 |
| Fang | 1990-08-27 | 2003-08-19 | 12 |
| Fluffy | 1993-02-04 | 2003-08-19 | 10 |
| Puffball | 1999-03-30 | 2003-08-19 | 4 |
| Slim | 1996-04-29 | 2003-08-19 | 7 |
| Whistler | 1997-12-09 | 2003-08-19 | 5 |
+----------+------------+------------+------+
要按age进行排序,只需使用不同的ORDER BY子句:
mysql> SELECT name, birth, CURDATE(),
TIMESTAMPDIFF(YEAR,birth,CURDATE()) AS age
FROM pet ORDER BY age;
+----------+------------+------------+------+
| name | birth | CURDATE() | age |
+----------+------------+------------+------+
| Chirpy | 1998-09-11 | 2003-08-19 | 4 |
| Puffball | 1999-03-30 | 2003-08-19 | 4 |
| Whistler | 1997-12-09 | 2003-08-19 | 5 |
| Slim | 1996-04-29 | 2003-08-19 | 7 |
| Claws | 1994-03-17 | 2003-08-19 | 9 |
| Fluffy | 1993-02-04 | 2003-08-19 | 10 |
| Fang | 1990-08-27 | 2003-08-19 | 12 |
| Bowser | 1989-08-31 | 2003-08-19 | 13 |
| Buffy | 1989-05-13 | 2003-08-19 | 14 |
+----------+------------+------------+------+
类似的查询可用于确定已死亡动物的死亡年龄。death您可以通过检查值 是否为 来确定这些动物NULL。然后,对于那些没有值的,计算和 值NULL之间的差: deathbirth
mysql> SELECT name, birth, death,
TIMESTAMPDIFF(YEAR,birth,death) AS age
FROM pet WHERE death IS NOT NULL ORDER BY age;
+--------+------------+------------+------+
| name | birth | death | age |
+--------+------------+------------+------+
| Bowser | 1989-08-31 | 1995-07-29 | 5 |
+--------+------------+------------+------+
查询使用death IS NOT NULL而不是death <> NULL因为它 NULL是一个特殊值,无法使用通常的比较运算符进行比较。
如果您想知道哪些动物下个月生日怎么办?对于这种类型的计算,年和日是无关的;您只想提取该 birth列的月份部分。MySQL 提供了多个用于提取部分日期的函数,例如 YEAR()、 MONTH()和 DAYOFMONTH()。 MONTH()是这里合适的函数。birth要了解其工作原理,请运行一个简单的查询来显示和 的值MONTH(birth):
mysql> SELECT name, birth, MONTH(birth) FROM pet;
+----------+------------+--------------+
| name | birth | MONTH(birth) |
+----------+------------+--------------+
| Fluffy | 1993-02-04 | 2 |
| Claws | 1994-03-17 | 3 |
| Buffy | 1989-05-13 | 5 |
| Fang | 1990-08-27 | 8 |
| Bowser | 1989-08-31 | 8 |
| Chirpy | 1998-09-11 | 9 |
| Whistler | 1997-12-09 | 12 |
| Slim | 1996-04-29 | 4 |
| Puffball | 1999-03-30 | 3 |
+----------+------------+--------------+
查找下个月生日的动物也很简单。假设当前月份是四月。那么月份值为,您可以像这样 4查找五月(月)出生的动物:5
mysql> SELECT name, birth FROM pet WHERE MONTH(birth) = 5;
+-------+------------+
| name | birth |
+-------+------------+
| Buffy | 1989-05-13 |
+-------+------------+
如果当前月份是 12 月,则会出现一个小问题。您不能仅在月份数字 ( 12) 上加一并查找出生于 月份 的动物 13,因为不存在这样的月份。相反,您寻找在一月(月 1)出生的动物。
您可以编写查询,以便无论当前月份是什么,它都可以工作,这样您就不必使用特定月份的数字。 DATE_ADD()
使您能够向给定日期添加时间间隔。如果将月份添加到 的值中CURDATE()
,然后用 提取月份部分MONTH()
,结果将生成要在其中查找生日的月份:
mysql> SELECT name, birth FROM pet
WHERE MONTH(birth) = MONTH(DATE_ADD(CURDATE(),INTERVAL 1 MONTH));
完成相同任务的另一种方法是, 使用模函数 ( ) 将月份值包装1为当前月份值后,添加以获取当前月份之后的下一个月: MOD012
mysql> SELECT name, birth FROM pet
WHERE MONTH(birth) = MOD(MONTH(CURDATE()), 12) + 1;
MONTH()1返回和之间的数字12。并 返回和MOD(something,12)之间的数字。所以加法必须在 后 ,否则我们将从 11 月 ( ) 到 1 月 ( )。 011MOD()111
如果计算使用无效日期,计算将失败并产生警告:
mysql> SELECT '2018-10-31' + INTERVAL 1 DAY;
+-------------------------------+
| '2018-10-31' + INTERVAL 1 DAY |
+-------------------------------+
| 2018-11-01 |
+-------------------------------+
mysql> SELECT '2018-10-32' + INTERVAL 1 DAY;
+-------------------------------+
| '2018-10-32' + INTERVAL 1 DAY |
+-------------------------------+
| NULL |
+-------------------------------+
mysql> SHOW WARNINGS;
+---------+------+----------------------------------------+
| Level | Code | Message |
+---------+------+----------------------------------------+
| Warning | 1292 | Incorrect datetime value: '2018-10-32' |
+---------+------+----------------------------------------+
总结
提示:这里对文章进行总结:
例如:以上就