我有三个表,即员工、部门和申诉。雇员表有超过一百万条记录。我需要找到员工的详细信息,他/她的部门以及他/她提出的申诉。
我可以想到以下两个查询来找到结果:
1、先过滤记录,只获取需要数据的员工的记录:
SELECT * FROM (SELECT * FROM Employees WHERE EmployeeID= @EmployeeID) Emp
LEFT JOIN Department Dpt ON Emp.EmployeeID= Dpt.EmployeeID
LEFT JOIN Grievance Grv ON Emp.EmployeeID= Grv.EmployeeID;
2、先加入:
SELECT * FROM Employees Emp
LEFT JOIN Department Dpt ON Emp.EmployeeID= Dpt.EmployeeID
LEFT JOIN Grievance Grv ON Emp.EmployeeID= Grv.EmployeeID
WHERE EmployeeID= @EmployeeID);
如果我们考虑以 FROM>INNER JOIN>OUTER JOIN>WHERE>....SELECT 开头的 SQL 逻辑处理顺序,第一个查询应该执行得更好/更快,因为内部查询中只有一条记录并且将被连接与进一步的表。但是,在执行这两个查询时,我没有发现任何性能差异,并且两个查询几乎都需要相同的时间。
你能检查一下,让我知道我在哪里想错了吗?