我在肯尼亚基苏木的一家医院有一个 openmrs 版本 1.9.7 的本地实现。由于 OpenMrs 数据库的复杂性,当我尝试编写查询以访问从数据库收集的患者数据以进行数据管理时,就会出现问题。我也对 sql 有点厌烦,因为我已经有一段时间没有练习了,但我需要尽快把数据拿出来。我目前的查询如下
SELECT p.date_created as date_enrolled, pi.identifier, pi.identifier_type identifier_type ,
pn.given_name,pn.middle_name, pn.family_name, p.person_id, p.gender, p.birthdate, p.death_date,
ob.obs_datetime, cm.name as obs_type, CASE co.datatype_id when '1' then ob.value_numeric
when '2' then (select name from concept_name where concept_id = ob.value_coded limit 1)
when '3' then ob.value_text when '6' then ob.value_datetime when '10' then ob.value_boolean when '13' then ob.value_complex else "N/A" END AS obs_value, e.encounter_datetime
FROM person p JOIN person_name pn ON p.person_id = pn.person_id
JOIN patient_identifier pi ON p.person_id = pi.patient_id
JOIN patient_identifier_type pit ON pit.patient_identifier_type_id = pi.identifier_type
JOIN obs ob ON p.person_id = ob.person_id JOIN encounter e ON e.encounter_id = ob.encounter_id
JOIN concept_name cm ON ob.concept_id = cm.concept_id
JOIN concept co ON ob.concept_id = co.concept_id
JOIN concept_datatype cdt ON cdt.concept_datatype_id = co.datatype_id;
是否有一个已经存在的查询可以用作启动器并可以修改以满足我的需求?或者更确切地说,你建议我如何最好地完成这个?
谢谢