這兩個查詢爲什麼會有這樣的差異?針對特定鍵值的慢SQL SELECT
這個查詢花費約51秒來完成:
SELECT TOP 1000 *
FROM [PHONER].[dbo].[V_PhonerSubjects]
WHERE ProjectID = 137;
然而,這種查詢採用約1秒至完成:
SELECT TOP 1000 *
FROM [PHONER].[dbo].[V_PhonerSubjects]
WHERE ProjectID = 107;
注意:唯一的區別是關鍵的值。
兩者共有超過1000條記錄。項目107有26000條記錄,項目137有4500條記錄。
ProjectID
是索引主鍵。
我注意到,第二個查詢在1秒內完成並將所有行發送到結果窗口。第一個查詢開始在大約3秒後發送行,並在大約51秒後完成。
這是查看V_PhonerSubjects
的SQL:
SELECT
dbo.PhonerEmner.PhonerEmID AS SubjectID, dbo.PhonerEmner.FK_ProID AS ProjectID,
dbo.PhonerProjekt.PhonerTitel AS ProjectName, dbo.Medlemsdata.Vennenr AS FriendNo,
dbo.Medlemsdata.OpretteDato AS CreatedDate, dbo.Medlemsdata.OpretteID AS CreatedID,
dbo.Bruger.Intialer AS CreatedBy, dbo.Medlemsdata.ÆndretDato AS ChangedDate,
dbo.Medlemsdata.ÆndretID AS ChangedID,
Bruger_3.Intialer AS ChangedBy,
ISNULL(dbo.Medlemsdata.Organisation, N'') + N' ' + ISNULL(dbo.Medlemsdata.Fornavn, N'') + N' ' + ISNULL(dbo.Medlemsdata.Efternavn, N'') AS Name,
dbo.MedlemsAdresse.AdrID AS AddressID, dbo.MedlemsAdresse.Adresse AS Address1,
dbo.MedlemsAdresse.Adresse2 AS Address2, dbo.MedlemsAdresse.Postnr AS ZIP,
dbo.Postnumre.[By] AS City, dbo.Medlemsdata.CPRnr AS CPRno,
dbo.Medlemsdata.Køn AS Gender, dbo.Medlemsdata.Telefon AS Phone01,
dbo.Medlemsdata.TlfNote1 AS Phone02Type, dbo.Medlemsdata.Tlf1 AS Phone02,
dbo.Medlemsdata.TlfNote2 AS Phone03Type, dbo.Medlemsdata.Tlf2 AS Phone03,
dbo.Medlemsdata.TlfNote3 AS Phone04Type,
dbo.Medlemsdata.Tlf3 AS Phone04, dbo.Medlemsdata.TlfSMS AS PhoneMobile,
dbo.Medlemsdata.[E-mail] AS Email, dbo.Medlemsdata.SPFelt1 AS SPField01,
dbo.Medlemsdata.SPFelt2 AS SPField02, dbo.Medlemsdata.SPFelt3 AS SPField03,
dbo.Medlemsdata.SPFelt4 AS SPField04, dbo.Medlemsdata.SPFelt5 AS SPField05,
dbo.Medlemsdata.SPFelt6 AS SPField06, dbo.Medlemsdata.SPFelt7 AS SPField07,
dbo.Medlemsdata.SPFelt8 AS SPField08, dbo.Medlemsdata.SPFelt9 AS SPField09,
dbo.Medlemsdata.SPFelt10 AS SPField10, dbo.Medlemsdata.SPFelt11 AS SPField11,
dbo.Medlemsdata.SPFelt12 AS SPField12, dbo.Medlemsdata.SPFelt13 AS SPField13,
dbo.Medlemsdata.SPFelt14 AS SPField14, dbo.PhonerEmner.SidsteKontakt AS LastContact,
dbo.PhonerEmner.AntalKontakt AS ContactTimes, dbo.PhonerEmner.KontaktDage AS ContactDays,
dbo.PhonerEmner.KontaktEfter AS ContactAfter,
dbo.PhonerEmner.PhonerIgen AS ContactAfterPhonerID,
Bruger_1.Navn AS ContactAfterPhonerName, dbo.PhonerEmner.PhonerNote,
dbo.PhonerEmner.Stemning AS Mood, dbo.PhonerEmner.Status,
dbo.PhonerEmner.PhonerAft AS LastPhonerID, Bruger_2.Navn AS LastPhonerName,
dbo.PhonerEmner.SlutNote AS EndNote, dbo.PhonerEmner.SlutDato AS EndDate,
dbo.PhonerImport.PhonerImportID AS ImportID, dbo.PhonerImportData.Status AS ImportStatus,
dbo.PhonerImport.ImportFileName, dbo.PhonerImport.ImportTime,
dbo.PhonerProjekt.SvarerIkkeTid
FROM
dbo.Bruger AS Bruger_1
RIGHT OUTER JOIN
dbo.PhonerProjekt
RIGHT OUTER JOIN
dbo.PhonerEmner ON dbo.PhonerProjekt.PhonerProID = dbo.PhonerEmner.FK_ProID
LEFT OUTER JOIN
dbo.PhonerImportData ON dbo.PhonerEmner.PhonerEmID = dbo.PhonerImportData.FK_PhonerEmID
LEFT OUTER JOIN
dbo.Bruger AS Bruger_2 ON dbo.PhonerEmner.PhonerAft = Bruger_2.BrugerID ON Bruger_1.BrugerID = dbo.PhonerEmner.PhonerIgen
LEFT OUTER JOIN
dbo.Bruger
RIGHT OUTER JOIN
dbo.Bruger AS Bruger_3
RIGHT OUTER JOIN
dbo.Medlemsdata ON Bruger_3.BrugerID = dbo.Medlemsdata.ÆndretID ON dbo.Bruger.BrugerID = dbo.Medlemsdata.OpretteID ON dbo.PhonerEmner.FK_Vennenr = dbo.Medlemsdata.Vennenr
LEFT OUTER JOIN
dbo.Postnumre
RIGHT OUTER JOIN
dbo.MedlemsAdresse ON dbo.Postnumre.Postnummer = dbo.MedlemsAdresse.Postnr ON dbo.Medlemsdata.FK_AdrID = dbo.MedlemsAdresse.AdrID
LEFT OUTER JOIN
dbo.PhonerImport ON dbo.PhonerImportData.FK_PhonerImportID = dbo.PhonerImport.PhonerImportID
項目107客戶端統計:
Client Execution Time 14:04:24
Query Profile Statistics
Number of INSERT, DELETE and UPDATE statements 0 0.0000
Rows affected by INSERT, DELETE, or UPDATE statements 0 0.0000
Number of SELECT statements 2 2.0000
Rows returned by SELECT statements 1001 1001.0000
Number of transactions 0 0.0000
Network Statistics
Number of server roundtrips 3 3.0000
TDS packets sent from client 3 3.0000
TDS packets received from server 241 241.0000
Bytes sent from client 340 340.0000
Bytes received from server 976874 976874.0000
Time Statistics
Client processing time 95 95.0000
Total execution time 391 391.0000
Wait time on server replies 296 296.0000
項目137客戶端統計:
Client Execution Time 13:58:28
Query Profile Statistics
Number of INSERT, DELETE and UPDATE statements 0 0.0000
Rows affected by INSERT, DELETE, or UPDATE statements 0 0.0000
Number of SELECT statements 2 2.0000
Rows returned by SELECT statements 1001 1001.0000
Number of transactions 0 0.0000
Network Statistics
Number of server roundtrips 3 3.0000
TDS packets sent from client 3 3.0000
TDS packets received from server 217 217.0000
Bytes sent from client 340 340.0000
Bytes received from server 877700 877700.0000
Time Statistics
Client processing time 129596 129596.0000
Total execution time 130297 130297.0000
Wait time on server replies 701 701.0000
如果您爲兩個語句單獨提供查詢執行計劃可能會有所幫助。在SQL Management Studio中,選擇「包括實際執行計劃」圖標(或使用Ctrl + M將其切換),並在查詢完成後獲取執行計劃,該計劃將作爲標籤爲「執行計劃」的選項卡提供查詢結果窗格。這些執行計劃對於每個查詢分別是什麼樣的? – Seibar 2014-12-04 20:32:44
也許過時的統計數據?在執行計劃中檢查估計的行與實際行返回 – 2014-12-04 20:35:17
請發佈2查詢計劃。 – 2014-12-04 21:00:06