[英]Left Outer Join Query Extremely Slow - SQL Server
Huge issue with an SQL Server Query! SQL Server查询的巨大问题!
So the query below utilizes JOIN commands in the query, but takes no less than 15-20 minutes to run! 因此,以下查询在查询中利用了JOIN命令,但是运行时间不少于15-20分钟! No idea how to better optimize this code :( 不知道如何更好地优化此代码:(
Any ideas on how to fix this issue? 有关如何解决此问题的任何想法?
SELECT dbo.DB_Timetrack.[JOB #], dbo.DB_Timetrack.[Last Name], dbo.DB_Timetrack.[First Name], dbo.DB_Timetrack.HOURS, dbo.DB_Timetrack.BEGDATE, dbo.DB_Timetrack.LOCATNID,
dbo.DB_Timetrack.DESCR, dbo.DB_Timetrack.CODE, dbo.DB_Timetrack.TYPE,
CASE WHEN dbo.DB_Job_status_open_and_closed.WS_Job_Number != '' THEN dbo.DB_Timetrack.Hours ELSE 0 END AS HoursWon, dbo.DB_Timetrack.NUMBERONLY,
dbo.DB_Job_status_open_and_closed.WS_Job_Number_Only, dbo.DB_Job_status_open_and_closed.CREATDDT, DATEDIFF(Day, dbo.DB_Timetrack.BEGDATE,
dbo.DB_Job_status_open_and_closed.CREATDDT) AS Date_Difference, DBCRM_MSCRM.dbo.DB_Opportunity_SalespersonID.new_GPSalespersonName,
CASE WHEN DBCRM_MSCRM.dbo.DB_Opportunity_SalespersonID.new_GPSalesRepCode <> '' THEN DBCRM_MSCRM.dbo.DB_Opportunity_SalespersonID.new_GPSalesRepCode ELSE dbo.DB_Job_status_open_and_closed.Salesperson
COLLATE Latin1_General_CI_AI END AS SalespersonID
FROM dbo.DB_Timetrack LEFT OUTER JOIN
DBCRM_MSCRM.dbo.DB_Opportunity_SalespersonID ON dbo.DB_Timetrack.NUMBERONLY COLLATE Latin1_General_CI_AI = DBCRM_MSCRM.dbo.DB_Opportunity_SalespersonID.Job_Num_Only LEFT OUTER JOIN
dbo.DB_Job_status_open_and_closed ON dbo.DB_Timetrack.NUMBERONLY = dbo.DB_Job_status_open_and_closed.WS_Job_Number_Only
WHERE (dbo.DB_Timetrack.HOURS > 0) AND (dbo.DB_Timetrack.DESCR <> '') AND (dbo.DB_Timetrack.BEGDATE > CONVERT(DATETIME, '2013-01-01 00:00:00', 102))
Any suggestions would be greatly appreciated! 任何建议将不胜感激!
This is basically your query: 这基本上是您的查询:
SELECT . . .
FROM dbo.DB_Timetrack LEFT OUTER JOIN
DBCRM_MSCRM.dbo.DB_Opportunity_SalespersonID
ON dbo.DB_Timetrack.NUMBERONLY COLLATE Latin1_General_CI_AI = DBCRM_MSCRM.dbo.DB_Opportunity_SalespersonID.Job_Num_Only LEFT OUTER JOIN
dbo.DB_Job_status_open_and_closed
ON dbo.DB_Timetrack.NUMBERONLY = dbo.DB_Job_status_open_and_closed.WS_Job_Number_Only
WHERE (dbo.DB_Timetrack.HOURS > 0) AND
(dbo.DB_Timetrack.DESCR <> '') AND
(dbo.DB_Timetrack.BEGDATE > CONVERT(DATETIME, '2013-01-01 00:00:00', 102))
1.) First, the collation statement is possibly killing any use of indexes. 1.)首先,排序规则语句可能会杀死对索引的任何使用。
2.) You need to be sure that you have indexes on DB_Job_status_open_and_closed(WS_Job_Number_Only)
and DB_Opportunity_SalespersonID(Job_Num_Only)
. 2.)您需要确保在DB_Job_status_open_and_closed(WS_Job_Number_Only)
和DB_Opportunity_SalespersonID(Job_Num_Only)
上具有索引。
3.) You might also find an index on DB_Timetrack(BEGDATE, HOURS, DESCR, NumberOnly)
to be helpful (the last three columns can be just include
if you are really using SQL Server). 3.)您可能还会在DB_Timetrack(BEGDATE, HOURS, DESCR, NumberOnly)
上找到一个索引DB_Timetrack(BEGDATE, HOURS, DESCR, NumberOnly)
,这将有所帮助(如果您确实在使用SQL Server,则最后三列可以include
)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.