繁体   English   中英

AQL嵌套数组值

[英]AQL nested array values

我对ArangoDB和AQL相当陌生,我的问题与嵌套数组值有关。 我不知道有没有办法做到这一点(或者即使我的查询被有效地编写了)

为了简短起见,我有2个收藏集。 一位代表“医师”,一位代表“适应症”。 每次我的患者去看医生咨询时,其症状列表都会记录在“适应症”集中。 但是,先前的诊断可能已由另一位医生做出。 在这种情况下,我的AQL语法如下所示:

FOR p in Patients
FILTER p._key=="cad010117"
RETURN {
   "name" : CONCAT(p.pfname, " ", p.plastname),
   "consultations" : (
       FOR i in Indications
       FILTER i.pat_id == p._key
          FOR d in Physicians
          FILTER i.ind_consul_doc == d._key

          RETURN {
              "Doctor" : CONCAT(d.dtitle, " ", d.dfirstname, " ", d.dlastname),
              "Consult Date" : i.ind_consul_dt,
              "Symptoms" : i.symptoms[*],
              "Past Diagnoses" : i.diagnosis[* RETURN {
                      "Condition" : CURRENT.diag, 
                      "Diagnosed on" : CURRENT.diag_dt, 
                      "Diagnosed by" : CURRENT.diag_doc
                  }
              ]
          }
   )

我相应的结果:

[
  {
    "name": "Alfred Jeffries",
    "consultations": [
      {
        "Doctor": "Dr Anthony Garcia",
        "Consult Date": "22nd Jun 2016",
        "Symptoms": [
          {
            "type": "hyperpyrexia",
            "details": "Temperature: 101",
            "duration": "3d"
          },
          {
            "type": "anxiety",
            "details": "Severe",
            "duration": "1w"
          },
          {
            "type": "mania",
            "details": "Moderate",
            "duration": "1w"
          },
          {
            "type": "diaphoresis",
            "details": "Increased sweating during the day only",
            "duration": "3d"
          }
        ],
        "Past Diagnoses": [
          {
            "Condition": "Bipolar Disorder",
            "Diagnosed on": "6th Jul 2016",
            "Diagnosed by": "dc666555"
          }
        ]
      }
    ]

我的问题是,对于返回的“过去诊断”数组, diag_doc字段是我的“适应症”集合中诊断数组内的一个值,对应于做出诊断的医生的“医师”集合中的_key值。 使用AQL返回diag_doc的全部详细信息的最佳方法是什么? 先感谢您。

PS:我正在使用ArangoDB 3.1.12

您可以使用子查询从Physicians集合中检索数据:

"Past Diagnoses": (FOR d IN i.diagnosis RETURN 
  {
    "Condition" : d.diag, 
    "Diagnosed on" : d.diag_dt,
    "Diagnosed by" : FIRST(FOR doc IN Physicians FILTER doc._key == d.diag_doc RETURN doc)
  }
)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM