我有这个查询的一个问题:LEFT OUTER JOIN产生不正确的语法
SELECT RTRIM(LTRIM(L_MAILITMS.MAILITM_FID)) AS Ref30
, IsNull (Ref33,0) as Ref33
FROM L_MAILITM_EVENTS
INNER JOIN L_MAILITMS ON L_MAILITM_EVENTS.MAILITM_PID = L_MAILITMS.MAILITM_PID
WHERE (L_MAILITMS.MAIL_CLASS_CD = 'E')
AND (L_MAILITM_EVENTS.EVENT_OFFICE_CD = 1063)
AND (L_MAILITM_EVENTS.EVENT_TYPE_CD = 30)
AND (L_MAILITM_EVENTS.EVENT_GMT_DT >= CONVERT(DATETIME, '2012-05-27 00:00:00', 102))
AND (L_MAILITM_EVENTS.EVENT_GMT_DT < CONVERT(DATETIME, '2012-05-28 00:00:00', 102))
LEFT OUTER JOIN
(
SELECT RTRIM(LTRIM(L_MAILITMS_1.MAILITM_FID)) as Ref3033
, COUNT(*) as Ref33
FROM L_MAILITM_EVENTS as L_MAILITM_EVENTS_1
INNER JOIN L_MAILITMS as L_MAILITMS_1 ON L_MAILITM_EVENTS_1.MAILITM_PID = L_MAILITMS_1.MAILITM_PID
WHERE (L_MAILITMS_1.MAIL_CLASS_CD = 'E')
AND (L_MAILITM_EVENTS_1.EVENT_OFFICE_CD = 1063)
AND (L_MAILITM_EVENTS_1.EVENT_TYPE_CD = 33)
AND (L_MAILITM_EVENTS_1.EVENT_GMT_DT >= CONVERT(DATETIME, '2012-05-27 00:00:00', 102))
GROUP BY L_MAILITMS_1.MAILITM_FID
) ON L_MAILITMS.MAILITM_FID = L_MAILITMS_1.MAILITM_FID
产生一个错误
消息156,级别15,状态1,行7
附近有语法错误关键字“LEFT”。
Msg 156,Level 15,State 1,Line 16
关键字'ON'附近的语法不正确。
表L_MAILITMS_EVENTS:
MAILITM_PID EVENT_OFFICE_CD EVENT_TYPE_CD
-----------------------------------------------------------
1 1063 30
2 1063 30
2 1063 33
3 1063 33
3 1063 30
4 1063 30
表L_MAILITMS:
MAILITM_PID MAILITM_FID MAIL_CLASS_CD
-------------------------------------------------------
1 123 E
2 452 E
3 369 E
4 633 E
我想什么:
Ref30 Ref33
-----------------------
123 0
452 1
369 1
633 0
UPDATE:感谢Sebas你[R帮助
*有另一种方式为这个查询,以保证速度的表现,因为我把约2500 MAILITM_FID?*
谁能帮助? 谢谢
'JOINs'是'FROM'的子条款,它们不能出现在'WHERE'之后 –
您想要做什么? –