-
Notifications
You must be signed in to change notification settings - Fork 124
CQL Cheat Sheet
Bryn Rhodes edited this page May 15, 2024
·
30 revisions
NOTE: This is a work-in-progress, we welcome your feedback!
Value | Description | Example |
---|---|---|
Null | The null literal | null |
Boolean | The boolean literals | true, false |
Integer | Sequences of digits in the range 0..231-1 | 16, -28 |
Long | Sequences of digits in the range 0..263-1 | 16000000000L, -28000000000L |
Decimal | Sequences of digits with a decimal point, in the range 0.0.. (1028-1)/108 | 100.015 |
String | Strings of any character enclosed within single-ticks (') | 'pending', 'active', 'complete' |
Date | The at-symbol (@) followed by an ISO-8601 compliant representation of a date | @2014-01-25 |
DateTime | The at-symbol (@) followed by an ISO-8601 compliant representation of a datetime | @2014-01-25T14:30:14.559
@2014-01T |
Time | The at-symbol (@) followed by an ISO-8601 compliant representation of a time | @T12:00
@T14:30:14.559 |
Quantity | An integer or decimal literal followed by a datetime precision specifier, or a UCUM unit specifier | 6 'gm/cm3'
80 'mm[Hg]'
3 months |
Ratio | A ratio of two quantities, separated by a colon (:) | 1:128
5 'mg' : 10 'mL' |
Code | Construct consistent with the way terminologies are typically represented | Code '66071002' from "SNOMED-CT" display 'Type B viral hepatitis' |
Concept | Construct to specify multiple terminologies used to code for the same concept | Concept {
Code '66071002' from "SNOMED-CT",
Code 'B18.1' from "ICD-10-CM"
} display 'Type B viral hepatitis' |
Tuple | Structured values that contain named elements, each having a value of some type | Tuple {
Name: 'Patrick',
DOB: @2014-01-01,
Address: Tuple { Line1: '41 Spinning Ave', City: 'Dayton', State: 'OH' },
Phones: { Tuple { Number: '202-413-1234', Use: 'Home' } }
} |
List | A collection of values of any type | { 1, 2, 3, 4, 5 }
[Condition: code in "Acute Pharyngitis"] |
Interval | Set of values between two boundaries that can be inclusive ([]) or exclusive (()) | Interval[3, 5) // 3 and 4, but not 5
Interval[@2014-01-01, @2015-01-01) // same as Interval[@2014-01-01, @2014-12-31] |
Symbol | Description |
---|---|
: | Definition operator, typically read as "defined as". Also used to separate the numerator from denominator in Ratio literals |
() | Parentheses for delimiting groups, as well as specifying and passing function parameters |
[] | Brackets for indexing into lists and strings, as well as delimiting the retrieve expression |
{} | Braces for delimiting lists and tuples |
<> | Angle-brackets for delimiting generic types within type specifiers |
. | Period for qualifiers and accessors |
, | Comma for delimiting items in a syntactic list |
= != ~ !~ <= < > >= | Comparison operators for comparing values |
+ - * / ^ | Arithmetic operators for performing calculations |
Type | Description | Example |
---|---|---|
Simple | Any alphabetical character or an underscore, followed by any number of alpha-numeric characters or underscores | Foo1 |
Delimited | any sequence of characters enclosed in backticks (`) | `Encounter, Performed` |
Quoted | Any sequence of characters enclosed in double-quotes (") | "Inpatient Encounters" |
Qualified | Identifiers can be combined using the qualifier operator (.) | Common.ConditionsIndicatingSexualActivity |
Type | Example |
---|---|
single-line | define "Foo": 1 + 1 // This is a single-line comment |
multi-line | /*
This is a multi-line comment
Any text enclosed within is ignored
*/ |
Construct | Description |
---|---|
library | Header information for the library, including the name and version, if any |
using | Data model information, specifying that the library may access types from the referenced data model |
include | Referenced library information, specifying that the library may access constructs defined in the referenced library |
codesystem | Codesystem information, specifying that logic within the library may reference the specified codesystem by the given name |
valueset | Valueset information, specifying that logic within the library may reference the specified valueset by the given name |
code | Code information, specifying that logic within the library may reference the specified code by the given name |
concept | Concept information, specifying that logic within the library may reference the specified concept by the given name |
parameter | Parameter information, specifying that the library expects parameters to be supplied by the evaluating environment |
context | Specifies the overall context, such as Patient or Practitioner, to be used in the statements that are declared in the library |
define | The basic unit of logic within a library, a define statement introduces a named expression that can be referenced within the library, or by other libraries |
function | A named expression that is allowed to take any number of arguments, each of which has a name and a declared type |
library ExampleLibraryWithAllDeclarations version '1.0.0'
using FHIR version '4.0.1'
include CommonLibrary called Common
codesystem LOINC: 'http://loinc.org'
valueset "Encounter Inpatient": 'http://cts.nlm.nih.gov/fhir/ValueSet/2.16.840.1.113883.3.666.5.307'
code "Blood Pressure Panel": '85354-9' from LOINC
concept "Blood Pressure Codes": { "Blood Pressure Panel" }
parameter "Measurement Period" default Interval[@2013-01-01, @2014-01-01)
context Patient
define "Inpatient Encounters":
[Encounter: "Encounter Inpatient"] Encounter
where Common.NormalizePeriod(Encounter.period) ends during day of "Measurement Period"
define "Most Recent Blood Pressure Labs":
MostRecent([Observation: "Blood Pressure Codes"])
define function MostRecent(observations List<Observation>):
Last(
observations O
sort by issued
)
Type | Example |
---|---|
Statement | define SimpleStatement: 'This is simple!' |
Function | define function MostRecent(observations List):
Last(
observations O
sort by issued
) |
Concept | Description | Example |
---|---|---|
Clinical Statement | Determines the structure of the data that is returned by the retrieve, as well as the semantics of the data involved | [Encounter] |
Filtering with Terminology | The retrieve expression allows the results to be filtered using terminology, including valuesets, code systems, or by specifying a single code | [Condition: "Diabetes"] |
Filtering with a Path | The terminology path can be set in the retrieve (otherwise defaults based on model info) | [Condition: severity in "Acute Severity"] |
Clause | Operation | Example |
---|---|---|
Relationship (with/without) | Allows relationships between the primary source and other clinical information to be used to filter the result | [Encounter: "Ambulatory/ED Visit"] E
with [Condition: "Acute Pharyngitis"] P
such that P.onset during E.period
and P.abatement after end of E.period |
Where | The where clause allows conditions to be expressed that filter the result to only the information that meets the condition | [Encounter: "Inpatient"] E
where duration in days of E.period >= 120 |
Return | The return clause allows the result set to be shaped as needed, removing elements, or including new calculated values | [Encounter: "Inpatient"] E
return duration in days of E.period |
Sort | The sort clause allows the result set to be ordered according to any criteria as needed | [Encounter: "Inpatient"] E
sort by start of period |