我正在从PHP中运行一个MySQL查询(用于防止暴力):
$stmt = $sql_connection->prepare(
'SELECT 1 FROM `ip_login` WHERE `ip` = ? AND `when` > ADDDATE(NOW(), INTERVAL -5 SECOND)');我想知道是否有一种方法可以防止数据库服务器计算每条记录的ADDDATE(NOW(), INTERVAL -5 SECOND),如下所示:
$stmt = $sql_connection->prepare(
'SELECT 1 FROM `ip_login` JOIN
(SELECT ADDDATE(NOW(), INTERVAL -5 SECOND) as 'when') as 'time'
ON `ip_login`.`when` > `time`.`when`
WHERE `ip_login`.`ip` = ?');我不计算PHP代码中的时间的原因是,如果有多个HTTP服务器处理同一个数据库,我就不需要保持它们的时间同步。
complicated?
发布于 2021-07-08 07:06:43
除非我们对数据库的结构有更多的了解,否则我们无法确定。
很可能在‘ip_login.time’上没有索引,当您可以有2个WHERE子句时,为什么要做一个自联接呢?
你可以用极限限制以后的结果。
而且,正如user3783243所提到的,您可以使用EXPLAIN来查看查询速度缓慢的原因。
https://stackoverflow.com/questions/68294664
复制相似问题