日期:2014-05-17  浏览次数:20627 次

SQL 查询超时,怎样优化?
SQL如下:
Select 
    'PT->FT' AS Staff_Status,        
    a.Staff_ID,
    CONVERT(CHAR(12),DATEADD(m,-1,@dt),3)+'- '+CONVERT(CHAR(12),(@dt-DAY(@dt)),3) AS Date,
    (SELECT SUM(e.Confirmed_Hours) FROM dbo.Attendance_Reports e
       WHERE a.Staff_ID=e.Staff_ID 
         AND e.EffectiveDate>=DATEADD(m,-1,@dt) AND e.EffectiveDate< @dt-DAY(@dt)+1) AS Hours,
    (SELECT COUNT(c.Day_Type) FROM dbo.Attendance_Reports c
       WHERE a.Staff_ID=c.Staff_ID AND  c.Staff_Status NOT IN ('PT')
         AND c.EffectiveDate>=DATEADD(m,-1,@dt) AND c.EffectiveDate< @dt-DAY(@dt)+1) AS Leave,
    'PT' AS Status
from dbo.Attendance_Reports AS a
WHERE (SELECT TOP 1 b.Staff_Status FROM dbo.Attendance_Reports b WHERE b.Staff_ID=a.Staff_ID AND b.EffectiveDate>=DATEADD(m,-1,@dt) AND b.EffectiveDate<DATEADD(m,1,@dt-DAY(@dt)+1)
             ORDER BY b.EffectiveDate ASC)='PT'
AND a.EffectiveDate >= DATEADD(m,-1,@dt) AND a.EffectiveDate<DATEADD(m,1,@dt-DAY(@dt)+1)
GROUP BY a.Staff_ID HAVING COUNT(DISTINCT a.Staff_Status)>1
---------01/09-30/09 Date---------
UNION ALL
Select 
    'PT->FT' AS Staff_Status,        
    a.Staff_ID,
    CONVERT(CHAR(12),(@dt-DAY(@dt)+1),3)+'- '+CONVERT(CHAR(12),DATEADD(m,1,(@dt-DAY(@dt))),3) AS Date,
    (SELECT FTCHTotal+PTCH0120 FROM dbo.SMW_Consolidate
       WHERE [Month]=MONTH(@dt) AND [Year]=YEAR(@dt)
             AND Staff_no=a.Staff_ID 
             AND Remark<>'Part Time') AS Hours,
    CAST((SELECT COUNT(c.Day_Type) FROM dbo.Attendance_Reports c
       WHERE a.Staff_ID=c.Staff_ID -- AND c.Staff_Status NOT IN ('PT')
         AND c.EffectiveDate>=@dt-DAY(@dt)+1 AND c.EffectiveDate<=(
  ISNULL((SELECT TOP 1 ResignDate
 FROM dbo.Attendance_HRM_Excel 
 WHERE ResignDate IS NOT NULL
 AND ResignDate<DATEADD(m,1,@dt-DAY(@dt))
 AND StaffNo=c.Staff_ID
 ORDER BY ResignDate),DATEADD(m,1,@dt-DAY(@dt)))
   )
         AND c.Day_Type NOT LIKE 'H%' AND c.Day_Type<>'ND')+
    (SELECT COUNT(c.Day_Type)*0.5 FROM dbo.Attendance_Reports c
       WHERE a.Staff_ID=c.Staff_ID -- AND c.Staff_Sta