5

我使用了以下查询:

select Patients.LastName, 
  avg (PatientVisits.Pulse)as pulse,
  avg (patientvisits.depressionlevel)as depressionLevel  
from Patients 
left join PatientVisits 
   on Patients.PatientKey=PatientVisits.PatientKey

但我收到以下错误:

消息 8120,级别 16,状态 1,第 1 行列“Patients.LastName”在选择列表中无效,因为它既不包含在聚合函数或 GROUP BY 子句中。

4

1 回答 1

10

您需要在GROUP BY查询中添加一个:

select Patients.LastName, 
   avg (PatientVisits.Pulse)as pulse,
   avg (patientvisits.depressionlevel)as depressionLevel  
from Patients 
left join PatientVisits 
  on Patients.PatientKey=PatientVisits.PatientKey 
GROUP BY Patients.LastName

SQL Server 要求SELECT列表中所有不在聚合函数中的列都包含在GROUP BY. 由于您试图在Patients.LastName聚合数据时返回,因此您必须将该列包含在分组依据中。

于 2013-08-28T16:09:50.627 回答