SQL 使用 max() 进行多个内连接以获取最新记录的条目

标签 sql max inner-join winsql

尝试使用 INNER JOIN 构建 SQL。 INNER JOIN 工作正常,现在我需要添加 MAX() 函数以将行限制为最近的行。添加了此 INNER JOIN client_diagnosis_record ON SELECT cr.PATID、cr.date_of_diagnosis、cr.most_recent_diagnosis... 收到这个 SQL 代码错误,需要一些帮助,我确信这是一个简单的疏忽,但我的眼睛因为看得太久而变得模糊......

语法错误:[SQLCODE: <-4>:

SQLCODE: <-4>:<A term expected, beginning with one of the following: identifier, constant, aggregate, %ALPHAUP, %EXACT, %MVR, %SQLSTRING, %

[%msg: < The SELECT list of the subquery


SELECT pd.patient_name,
       cr.PATID,
       cr.date_of_diagnosis,
       cr.EPISODE_NUMBER,
       ce.diagnosing_clinician_value, 
       ce.data_entry_user_name,
       most_recent_diagnosis
FROM client_diagnosis_record cr 
INNER JOIN patient_current_demographics pd ON cr.patid = pd.patid 
INNER JOIN client_diagnosis_entry ce ON ce.patid = pd.patid
                                    AND cr.ID = ce.DiagnosisRecord
INNER JOIN client_diagnosis_record ON (SELECT cr.PATID,
                                              cr.date_of_diagnosis,
                                              cr.most_recent_diagnosis
                                       FROM ( SELECT patid,
                                                     date_of_diagnosis,
                                                     MAX(ID) AS most_recent_diagnosis
                                              FROM client_diagnosis_record) cr
 INNER JOIN RADplus_users ru ON ru.staff_member_id = ce.diagnosing_clinician_code
 WHERE cr.PATID <> '1'
 AND ce.diagnosis_status_value ='Active'
 AND (ru.user_description LIKE '%SOA' OR ru.user_description LIKE '%OA')
 GROUP BY cr.PATID

最佳答案

我尝试重新格式化您的查询,但您的查询语法似乎不正确。您可以尝试以下查询 -

SELECT pd.patient_name,
       cr.PATID,
       cr.date_of_diagnosis,
       cr.EPISODE_NUMBER,
       ce.diagnosing_clinician_value, 
       ce.data_entry_user_name,
       most_recent_diagnosis
FROM client_diagnosis_record cr
INNER JOIN (SELECT patid,
                   date_of_diagnosis,
                   MAX(ID) AS most_recent_diagnosis
            FROM client_diagnosis_record
            GROUP BY patid,
                     date_of_diagnosis) cr2 ON cr.PATID = cr2.PATID
                                            AND cr.date_of_diagnosis = cr2.date_of_diagnosis
                                            AND cr.ID = cr2.most_recent_diagnosis
INNER JOIN patient_current_demographics pd ON cr.patid = pd.patid 
INNER JOIN client_diagnosis_entry ce ON ce.patid = pd.patid
                                    AND cr.ID = ce.DiagnosisRecord
INNER JOIN RADplus_users ru ON ru.staff_member_id = ce.diagnosing_clinician_code
WHERE cr.PATID <> '1'
AND ce.diagnosis_status_value ='Active'
AND (ru.user_description LIKE '%SOA' OR ru.user_description LIKE '%OA')
GROUP BY cr.PATID

关于SQL 使用 max() 进行多个内连接以获取最新记录的条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57715502/

相关文章:

sql - 需要一个SQL查询来获取基于计数的条件数据

mysql - SQL GROUP BY来自两列的计算值

matlab - 合并表而不按键排序

php - 如何从同一张表中获取相关行?

SQL 按组名称求和并存在内连接

javascript - Ajax 数据管理

sql - UTC时间对应的本地时间

sql - 使用 MAX 和 GROUP BY 选择所有对应的字段

python - 实现自定义最大功能

mysql - vb.net 的最小值和最大值