mysql id 范围_Mysql:2个ID的主键上的内连接给出“为每个记录检查范围”

当在具有2个值(使用IN或OR结构)的PRIMARY键上进行INNER JOIN时,我在EXPLAIN SELECT中获得“检查每个记录的范围(索引映射:0x1)”

这是查询:

SELECT *

FROM message AS m

INNER JOIN user AS u

ON u.id = m.sender_id OR u.id = m.receiver_id

在做解释时,它给了我:

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

| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |

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

| 1 | SIMPLE | u | ALL | PRIMARY | null | null | null | 75000 | Range checked for each record (index map: 0x1)|

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

它不可能……

如果我尝试这个,我会得到相同的结果:

SELECT *

FROM message AS m

INNER JOIN user AS u

ON u.id IN(m.sender_id, m.receiver_id)

但是,如果我这样做,它工作正常,我只解析了1行:

SELECT *

FROM message AS m

INNER JOIN user AS u

ON u.id = m.sender_id

这怎么可能?我正在加入具有相同类型值的主键. (实际的查询是“有点”更复杂,但没有什么花哨,2个内连接,最后一个左连接)

它应该是2行,周期.

感谢您的任何意见(进行了一些研究,但除了“请添加索引”之外没有找到任何有价值的东西,这显然不适用于此处)

编辑:是的,我尝试了USE INDEX声明,但仍然没有运气

编辑:这是一个非常简单的架构来重现MySQL的这种奇怪的行为:

CREATE TABLE test_user (

id INT NOT NULL AUTO_INCREMENT,

name VARCHAR(30),

PRIMARY KEY (id)

);

CREATE TABLE test_message (

id INT NOT NULL AUTO_INCREMENT,

sender_id INT NOT NULL,

receiver_id INT NOT NULL,

PRIMARY KEY (id),

INDEX idx_sender (sender_id),

INDEX idx_receiver (receiver_id)

);

EXPLAIN SELECT *

FROM test_message AS m

INNER JOIN test_user AS u

ON u.id = m.sender_id OR u.id = m.receiver_id;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值