Search code examples
parsinghl7hl7-v2

HL7 ADT Message parsing: date ranges


Note:

This question is not asking for advice on which library to use; I'm rolling my own.


I'm reading through the HL7 v2.5.1 spec in order to make a parsing engine for iOS and Windows.

My question is related to the Name Validity Range component in the Patient Name field (PID-5). But I think it applies generally to all DR (Date Range) components.

In Chapter 3: Patient Administration, on page 75, the following information is listed:

Components: {...omitted...} ^ <Name Validity Range (DR)> ^ {...omitted...}

Subcomponents for Name Validity Range (DR): <Range Start Date/Time (TS)> & <Range End Date/Time (TS)>

Subcomponents for Range Start Date/Time (TS): <Time (DTM)> & <Degree of Precision (ID)>

Subcomponents for Range End Date/Time (TS): <Time (DTM)> & <Degree of Precision (ID)>

I understand how the fields, components and subcomponents are structured and how their separators are used... or at least I think I do. However, the above information confuses me as to how the data would be expressed. I have searched, but cannot find a suitable message sample for this kind of data. Based on my understanding of the HL7 data structures, here's how the data would be encoded:

PID|||01234||JONES^SUSIE^Q^^^^^^^199505011201&M&199505011201&M^199505011201&M&199505011201&M

The problem here, of course, is that having subcomponents embedded in subcomponents leaves you unsure exactly how to parse the data and what data goes where.

I did look into Chapter 2: Control, Appendix A and found this text on page 160:

Note: DR cannot be legally expressed when embedded within another data type. Its use is constrained to a segment field.

So, it appears that the standard listed for PID-5 is invalid. I haven't seen any messages from my system that even generate this information, so it may be a moot point for my particular case, but I don't like developing solutions with known holes. Has anybody encountered this "in the wild"?


Solution

  • An item with DR data type can be subdivided and have a precision subcomponent if the item is of type field .eg. ARQ/11 Requested start date/time range.

    It can be subdivided in start and end of data range subcomponents but not precision subcomponent if the item with DR data type is already part of an other data type as in your example PID/5.