mysql between 空值_mysql中between关键字避免踩坑

创建一张测试表,并写入测试数据CREATE TABLE `t_test` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`create_time` datetime DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

insert into t_test(create_time) values

('2020-02-26 00:00:00'),

('2020-02-26 23:59:59'),

('2020-02-27 00:00:00'),

('2020-02-27 02:59:59'),

('2020-02-27 23:59:59'),

('2020-02-28 00:00:00'),

('2020-02-28 00:00:00'),

('2020-02-28 02:59:59'),

('2020-02-28 08:59:59');

按精确到秒的方式进行between查询mysql> select * from t_test where create_time between '2020-02-27 00:00:00' and '2020-02-28 00:00:00';

+----+---------------------+

| id | create_time |

+----+---------------------+

| 3 | 2020-02-27 00:00:00 |

| 4 | 2020-02-27 02:59:59 |

| 5 | 2020-02-27 23:59:59 |

| 6 | 2020-02-28 00:00:00 |

| 7 | 2020-02-28 00:00:00 |

+----+---------------------+

5 rows in set (0.00 sec)

可以看到between是两端都包含的语义

按照日期范围between查询mysql> select * from t_test where create_time between '2020-02-27' and '2020-02-28';

+----+---------------------+

| id | create_time |

+----+---------------------+

| 3 | 2020-02-27 00:00:00 |

| 4 | 2020-02-27 02:59:59 |

| 5 | 2020-02-27 23:59:59 |

| 6 | 2020-02-28 00:00:00 |

| 7 | 2020-02-28 00:00:00 |

+----+---------------------+

5 rows in set (0.00 sec)

这里有坑:可能以为查询的结果是会包含了2020-02-27、2020-02-28这两天的数据,但实际上28日只会包含0时0分0秒这个时间点的数据,不会包含当天其他时间点的数据。如果没有搞清楚的话,可能会导致我们误以为按日期查询右值是闭区间,是exclude的;或者sql大部分时间没有问题,一旦有了0时0分0秒的数据,就会出现诡异的BUG。

按照日期查询的效果和加上0时0分0秒是一样的,因为mysql在执行查询之前,就是先把日期转成对应0时0分0秒时的时间戳,然后进行匹配查询的。

另一个按照日期范围的between查询mysql> select * from t_test where create_time between 20200227 and 20200228;

+----+---------------------+

| id | create_time |

+----+---------------------+

| 3 | 2020-02-27 00:00:00 |

| 4 | 2020-02-27 02:59:59 |

| 5 | 2020-02-27 23:59:59 |

| 6 | 2020-02-28 00:00:00 |

| 7 | 2020-02-28 00:00:00 |

+----+---------------------+

5 rows in set (0.00 sec)

就算传递的是整数,传递yyyyMMdd格式的日期,mysql也能够识别这个方式的日期数据,实际效果和上面的yyyy-MM-dd是一样的。

总结

between是两端开区间(包含)的语义,使用between时要注意日期范围查询可能会导致的问题。

大多数情况下,建议使用create_time >= 20200227 and create_time < 20200228这样方式进行范围查询。

、>=的语义描述是精确的,不会产生误解。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值