如果我使用具有无效日期的 INTERVAL 关键字,MySQL 的行为如何?
实际上,MySQL的行为取决于allow_invalid_dates模式。如果启用此模式,则MySQL将接受无效日期,并且它将执行日期算术,就像它对有效日期执行的那样。否则,如果此模式处于非活动状态,则它将不接受无效日期并将产生NULL作为输出。
mysql> select '2017-02-30' + INTERVAL 7 day; +-------------------------------+ | '2017-02-30' + INTERVAL 7 day | +-------------------------------+ | NULL | +-------------------------------+ 1 row in set, 1 warning (0.00 sec)
现在启用allow_invalid_date模式后,MySQL接受无效日期并按如下方式执行日期算术-
mysql> set sql_mode = allow_invalid_dates; mysql> select '2017-02-30' + INTERVAL 7 day; +-------------------------------+ | '2017-02-30' + INTERVAL 7 day | +-------------------------------+ | 2017-03-09 | +-------------------------------+ 1 row in set (0.00 sec) mysql> select '2017-11-31' + INTERVAL 7 day; +-------------------------------+ | '2017-11-31' + INTERVAL 7 day | +-------------------------------+ | 2017-12-08 | +-------------------------------+ 1 row in set (0.00 sec)
热门推荐
6 保研的祝福语简短
10 年轻20岁祝福语简短
11 朋友结婚祝福语信息简短
12 女孩婚礼贺卡祝福语简短
13 30段点歌简短祝福语
14 虎年春节祝福语图文简短
15 写给后妈祝福语大全简短
16 简短回复生日祝福语
17 校长送毕业祝福语简短
18 毕业立体贺卡祝福语简短