mysql计数包含LEFT JOIN的查询中的行挂起服务器



我有两个表。表people包含16500行,visits包含17000行。我的查询包含LEFT JOIN,因为我必须将visits链接到people。我知道,如果有没有访问记录的人员记录,那么这些访问列将为NULL。

这个简单的查询就像一个符咒。

SELECT * FROM people LEFT JOIN visits ON people.id = visits.id_people;

但是当我尝试计数返回的行时,MySQL会挂起(或计数)30秒或,直到我杀死它。这在生产环境中是不可接受的。

以下是我尝试用于计算结果行数的不同方法,但所有方法都有相同的挂起结果。

SELECT COUNT(*) FROM people LEFT JOIN visits ON people.id = visits.id_people;
SELECT SQL_CALC_FOUND_ROWS * FROM people LEFT JOIN visits ON people.id = visits.id_people;
SELECT FOUND_ROWS();

奇怪的是,这些方法在小型测试表(5行和5行)上运行良好。

有人能帮忙吗?

如果您正在创建一个新的MySQL表,您可以使用index术语指定要索引的列。索引是您可以在MySQL表上启用的额外功能,以提高性能
http://www.databasejournal.com/features/mysql/article.php/1382791/Optimizing-MySQL-Queries-and-Indexes.htm
http://www.tutorialspoint.com/mysql/mysql-indexes.htm看看这个,它会给你很多想法。。

欢呼

最新更新