MySQL DATE_ADD() 如何基于另一列中的值来增加日期?


我们先创建一个表格,其中一列是 DueDate,另一列是 “RepeatTime,它显示提醒用户提交付款的次数,例如 −

mysql> create table DemoTable
   -> (
   -> DueDate date,
   -> RepeatTime int
   -> );
Query OK, 0 rows affected (0.57 sec)

使用 insert 命令插入一些记录到表格中 −

mysql> insert into DemoTable values('2019-01-23',3);
Query OK, 1 row affected (0.13 sec)

mysql> insert into DemoTable values('2019-06-22',6);
Query OK, 1 row affected (0.19 sec)

mysql> insert into DemoTable values('2019-03-28',2);
Query OK, 1 row affected (0.25 sec)

mysql> insert into DemoTable values('2017-07-25',6);
Query OK, 1 row affected (0.15 sec)

使用 select 语句显示表格中的所有记录 −

mysql> select *from DemoTable;

输出

将产生以下输出 −

+------------+------------+
| DueDate    | RepeatTime |
+------------+------------+
| 2019-01-23 |          3 |
| 2019-06-22 |          6 |
| 2019-03-28 |          2 |
| 2017-07-25 |          6 |
+------------+------------+
4 rows in set (0.00 sec)

以下是根据另一列中的值增加日期的查询 −

mysql> update DemoTable set DueDate=date_add(DueDate,interval RepeatTime MONTH)
where RepeatTime!=6;
Query OK, 2 rows affected (0.25 sec)
Rows matched: 2 Changed: 2 Warnings: 0

让我们再次查看表格记录 −

mysql> select *from DemoTable;

输出

将产生以下输出 −

+------------+------------+
| DueDate    | RepeatTime |
+------------+------------+
| 2019-04-23 | 3          |
| 2019-06-22 | 6          |
| 2019-05-28 | 2          |
| 2017-07-25 | 6          |
+------------+------------+
4 rows in set (0.00 sec)

更新于:30-6 月-2020

642 次查看

开启您的 职业

通过完成课程获得认证

开始
广告