0

我有两个表,一个消息表和一个日志表。

我想返回消息表中已记录给用户并且其消息 # 大于传递的参数的所有行。

我所拥有的是:

SELECT * FROM message WHERE id IN ( SELECT msg_id AS id FROM msg_log WHERE user_num='1000' AND msg_id >='1660192')

此查询不返回任何内容,不产生任何错误,只是超时......它是从 PHP 脚本还是从 phpMyAdmin 运行都没有关系。事实上,如果从 phpMyAdmin 运行,它甚至不会显示查询正在运行,但它不允许您执行另一个查询。

如果我打破IN选择

SELECT msg_id AS id FROM msg_log WHERE user_num='1000' AND msg_id >='1660192')

这将返回 0 条记录(应该如此)

我该如何解决这个问题?

4

3 回答 3

2

试试这个:

SELECT message.* FROM message 
INNER JOIN msg_log 
    ON message.id = msg_log.msg_id
   AND msg_log.user_num = '1000' 
   AND msg_logmsg_id >= '1660192'

INNER JOIN语法应该比IN从句快。
自然,您可以加快查询速度

  • message.idINDEXPRIMARY_KEY
  • msg_log.id 作为INDEX并且可能与message.id相关FOREIGN_KEY
于 2012-08-20T19:54:55.197 回答
0

您是否尝试过在没有 php 的情况下从 mysql 监视器执行此查询?您可能有大表,mysql 需要更多时间来执行查询,而不是 php 脚本所允许的时间。你可以试试:

1) 在 msg_log 表中的 user_num 上添加索引可以加快查询速度,

2)设置允许php执行更长的php_max_execution_time脚本.htaccess

于 2012-08-20T19:53:50.417 回答
0

由于 MySQL 的特殊性,内连接比 IN 快。MySQL 所做的是为它遇到的每一行运行子查询。这对于数据库来说是不寻常的行为,但已记录在案。

加入解决了这个问题。但是,正确的等效语法需要一个不同的:

SELECT m.*
FROM message m join
     (select distinct msg_id
      from msg_log
      WHERE user_num='1000' AND msg_id >='1660192'
     ) ml
     on ml.msg_id = m.id

如果您想避免每条消息有多行,则不同点很重要。

您还可以使用 EXISTS 子句修复它:

SELECT *
FROM message m
WHERE EXISTS (SELECT 1
              FROM msg_log ml
              WHERE user_num='1000' AND msg_id >='1660192' and m.id = ml.msg_id
             )

如果您更喜欢关联子查询而不是连接。

于 2012-08-20T20:08:22.623 回答