ฉันเห็นข้อผิดพลาดที่คล้ายกันใน SO แต่ฉันไม่พบวิธีแก้ไขปัญหาของฉัน ฉันมีแบบสอบถาม SQL เช่น:
SELECT DISTINCT
a.maxa ,
b.mahuyen ,
a.tenxa ,
b.tenhuyen ,
ISNULL(dkcd.tong, 0) AS tongdkcd
FROM phuongxa a ,
quanhuyen b
LEFT OUTER JOIN ( SELECT maxa ,
COUNT(*) AS tong
FROM khaosat
WHERE CONVERT(DATETIME, ngaylap, 103) BETWEEN 'Sep 1 2011'
AND
'Sep 5 2011'
GROUP BY maxa
) AS dkcd ON dkcd.maxa = a.maxa
WHERE a.maxa <> '99'
AND LEFT(a.maxa, 2) = b.mahuyen
ORDER BY maxa;
เมื่อฉันเรียกใช้คิวรีนี้ผลลัพธ์ข้อผิดพลาดคือ:
ตัวระบุหลายส่วน "a.maxa" ไม่สามารถผูกได้ ทำไม?
P / s: ถ้าฉันแบ่งแบบสอบถามเป็น 2 แบบสอบถามแต่ละมันก็โอเค
SELECT DISTINCT
a.maxa ,
b.mahuyen ,
a.tenxa ,
b.tenhuyen
FROM phuongxa a ,
quanhuyen b
WHERE a.maxa <> '99'
AND LEFT(a.maxa, 2) = b.mahuyen
ORDER BY maxa;
และ
SELECT maxa ,
COUNT(*) AS tong
FROM khaosat
WHERE CONVERT(DATETIME, ngaylap, 103) BETWEEN 'Sep 1 2011'
AND 'Sep 5 2011'
GROUP BY maxa;
phuongxa
ตารางใส่คอลัมน์maxa
?